renamed notebook sample
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@6712 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
		
							
								
								
									
										315
									
								
								samples/notebook/notebook.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										315
									
								
								samples/notebook/notebook.cpp
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,315 @@
 | 
			
		||||
/////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
// Name:        notebook.cpp
 | 
			
		||||
// Purpose:     wxNotebook demo
 | 
			
		||||
// Author:      Julian Smart
 | 
			
		||||
// Modified by:
 | 
			
		||||
// Created:     26/10/98
 | 
			
		||||
// RCS-ID:      $Id$
 | 
			
		||||
// Copyright:   (c)
 | 
			
		||||
// Licence:     wxWindows licence
 | 
			
		||||
/////////////////////////////////////////////////////////////////////////////
 | 
			
		||||
 | 
			
		||||
// For compilers that support precompilation, includes "wx.h".
 | 
			
		||||
#include "wx/wxprec.h"
 | 
			
		||||
 | 
			
		||||
#ifdef __BORLANDC__
 | 
			
		||||
    #pragma hdrstop
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#ifndef WX_PRECOMP
 | 
			
		||||
    #include "wx/wx.h"
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include "notebook.h"
 | 
			
		||||
 | 
			
		||||
// If 1, use a dialog. Otherwise use a frame.
 | 
			
		||||
#define USE_TABBED_DIALOG 0
 | 
			
		||||
#if USE_TABBED_DIALOG
 | 
			
		||||
MyDialog* dialog = (MyDialog *) NULL;
 | 
			
		||||
#else // !USE_TABBED_DIALOG
 | 
			
		||||
MyFrame*  frame = (MyFrame *) NULL;
 | 
			
		||||
#endif // USE_TABBED_DIALOG
 | 
			
		||||
 | 
			
		||||
IMPLEMENT_APP(MyApp)
 | 
			
		||||
 | 
			
		||||
bool MyApp::OnInit()
 | 
			
		||||
{
 | 
			
		||||
  // Create the main window
 | 
			
		||||
#if USE_TABBED_DIALOG
 | 
			
		||||
  dialog = new MyDialog((wxFrame *) NULL, -1, (char *) "Notebook", wxPoint(-1, -1), wxSize(365, 390), wxDIALOG_MODAL|wxDEFAULT_DIALOG_STYLE);
 | 
			
		||||
 | 
			
		||||
  dialog->ShowModal();
 | 
			
		||||
 | 
			
		||||
  // Quit immediately the dialog has been dismissed
 | 
			
		||||
  return FALSE;
 | 
			
		||||
#else
 | 
			
		||||
  frame = new MyFrame((wxFrame*) NULL, -1, "Notebook", wxPoint(-1, -1), wxSize(465, 390) );
 | 
			
		||||
 | 
			
		||||
  // 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, wxPanel* window)
 | 
			
		||||
{
 | 
			
		||||
  m_okButton = new wxButton(window, wxID_OK, "Close", 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_insertPageButton = new wxButton(window, ID_INSERT_PAGE, "&Insert page", wxPoint(-1, -1), wxSize(80, 25));
 | 
			
		||||
  m_nextPageButton = new wxButton(window, ID_NEXT_PAGE, "&Next page", wxPoint(-1, -1), wxSize(80, 25));
 | 
			
		||||
  m_okButton->SetDefault();
 | 
			
		||||
 | 
			
		||||
  wxLayoutConstraints *c;
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->right.SameAs(window, wxRight, 4);
 | 
			
		||||
  c->bottom.SameAs(window, wxBottom, 4);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->width.AsIs();
 | 
			
		||||
  m_addPageButton->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->right.SameAs(m_addPageButton, wxLeft, 4);
 | 
			
		||||
  c->bottom.SameAs(window, wxBottom, 4);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->width.AsIs();
 | 
			
		||||
  m_insertPageButton->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->right.SameAs(m_insertPageButton, wxLeft, 4);
 | 
			
		||||
  c->bottom.SameAs(window, wxBottom, 4);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->width.AsIs();
 | 
			
		||||
  m_nextPageButton->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->right.SameAs(m_nextPageButton, wxLeft, 4);
 | 
			
		||||
  c->bottom.SameAs(window, wxBottom, 4);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->width.AsIs();
 | 
			
		||||
  m_cancelButton->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->right.SameAs(m_cancelButton, wxLeft, 4);
 | 
			
		||||
  c->bottom.SameAs(window, wxBottom, 4);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->width.AsIs();
 | 
			
		||||
  m_okButton->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  // Add some panels
 | 
			
		||||
  wxPanel *panel1 = new wxPanel(notebook, -1);
 | 
			
		||||
  //  panel1->SetBackgroundColour(wxColour("RED"));
 | 
			
		||||
  (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", TRUE);
 | 
			
		||||
 | 
			
		||||
  wxPanel *panel2 = new wxPanel(notebook, -1);
 | 
			
		||||
  panel2->SetAutoLayout(TRUE);
 | 
			
		||||
  panel2->SetBackgroundColour(wxColour("BLUE"));
 | 
			
		||||
 | 
			
		||||
  wxString animals[] = { "Fox", "Hare", "Rabbit", "Sabre-toothed tiger", "T Rex" };
 | 
			
		||||
  wxRadioBox *radiobox = new wxRadioBox(panel2, -1, "Choose one",
 | 
			
		||||
                                        wxDefaultPosition, wxDefaultSize, 5, animals,
 | 
			
		||||
                                        2, wxRA_SPECIFY_ROWS);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->left.SameAs(panel2, wxLeft, 10);
 | 
			
		||||
  c->top.SameAs(panel2, wxTop, 5);
 | 
			
		||||
  c->height.PercentOf(panel2, wxHeight, 50);
 | 
			
		||||
  c->right.SameAs(panel2, wxRight, 10);
 | 
			
		||||
  radiobox->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  wxRadioBox *radiobox2 = new wxRadioBox(panel2, -1, "Choose one",
 | 
			
		||||
                                         wxDefaultPosition, wxDefaultSize,
 | 
			
		||||
                                         5, animals,
 | 
			
		||||
                                         2, wxRA_SPECIFY_ROWS);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->left.SameAs(radiobox, wxLeft);
 | 
			
		||||
  c->height.AsIs();
 | 
			
		||||
  c->top.Below(radiobox, 5);
 | 
			
		||||
  c->right.SameAs(radiobox, wxRight);
 | 
			
		||||
  radiobox2->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  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");
 | 
			
		||||
 | 
			
		||||
  notebook->SetSelection(2);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if USE_TABBED_DIALOG
 | 
			
		||||
 | 
			
		||||
BEGIN_EVENT_TABLE(MyDialog, wxDialog)
 | 
			
		||||
    EVT_BUTTON(wxID_OK, MyDialog::OnOK)
 | 
			
		||||
    EVT_BUTTON(wxID_CANCEL, MyDialog::OnOK)
 | 
			
		||||
END_EVENT_TABLE()
 | 
			
		||||
 | 
			
		||||
MyDialog::MyDialog(wxWindow* parent, const wxWindowID id, const wxString& title,
 | 
			
		||||
    const wxPoint& pos, const wxSize& size, const long windowStyle):
 | 
			
		||||
  wxDialog(parent, id, title, pos, size, windowStyle)
 | 
			
		||||
{
 | 
			
		||||
    Init();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyDialog::OnOK(wxCommandEvent& WXUNUSED(event) )
 | 
			
		||||
{
 | 
			
		||||
    EndModal(wxID_OK);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyDialog::OnCloseWindow(wxCloseEvent& WXUNUSED(event) )
 | 
			
		||||
{
 | 
			
		||||
    EndModal(wxID_CANCEL);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyDialog::Init()
 | 
			
		||||
{
 | 
			
		||||
  m_notebook = new wxNotebook(this, ID_NOTEBOOK);
 | 
			
		||||
 | 
			
		||||
  wxLayoutConstraints* c = new wxLayoutConstraints;
 | 
			
		||||
  c->left.SameAs(this, wxLeft, 4);
 | 
			
		||||
  c->right.SameAs(this, wxRight, 4);
 | 
			
		||||
  c->top.SameAs(this, wxTop, 4);
 | 
			
		||||
  c->bottom.SameAs(this, wxBottom, 40);
 | 
			
		||||
 | 
			
		||||
  m_notebook->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  wxGetApp().InitTabView(m_notebook, this);
 | 
			
		||||
 | 
			
		||||
  SetAutoLayout(TRUE);
 | 
			
		||||
  Layout();
 | 
			
		||||
 | 
			
		||||
  Centre(wxBOTH);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#else // USE_TABBED_DIALOG
 | 
			
		||||
 | 
			
		||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
 | 
			
		||||
    EVT_BUTTON(wxID_OK, MyFrame::OnOK)
 | 
			
		||||
    EVT_BUTTON(ID_DELETE_PAGE, MyFrame::OnDeletePage)
 | 
			
		||||
    EVT_BUTTON(ID_ADD_PAGE, MyFrame::OnAddPage)
 | 
			
		||||
    EVT_BUTTON(ID_INSERT_PAGE, MyFrame::OnInsertPage)
 | 
			
		||||
    EVT_BUTTON(ID_NEXT_PAGE, MyFrame::OnNextPage)
 | 
			
		||||
    EVT_IDLE(MyFrame::OnIdle)
 | 
			
		||||
END_EVENT_TABLE()
 | 
			
		||||
 | 
			
		||||
MyFrame::MyFrame(wxFrame* parent, const wxWindowID id, const wxString& title,
 | 
			
		||||
    const wxPoint& pos, const wxSize& size, const long windowStyle):
 | 
			
		||||
  wxFrame(parent, id, title, pos, size, windowStyle)
 | 
			
		||||
{
 | 
			
		||||
    m_panel = (wxPanel*) NULL;
 | 
			
		||||
    m_notebook = (wxNotebook*) NULL;
 | 
			
		||||
    Init();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnAddPage(wxCommandEvent& WXUNUSED(event))
 | 
			
		||||
{
 | 
			
		||||
    static size_t s_pageAdded = 0;
 | 
			
		||||
 | 
			
		||||
    wxPanel *panel = new wxPanel( m_notebook, -1 );
 | 
			
		||||
    (void)new wxButton( panel, -1, "Button", wxPoint( 10,10 ), wxSize(-1,-1) );
 | 
			
		||||
 | 
			
		||||
    m_notebook->AddPage( panel, wxString::Format("Added %u", ++s_pageAdded) );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnInsertPage(wxCommandEvent& WXUNUSED(event))
 | 
			
		||||
{
 | 
			
		||||
    static size_t s_pageIns = 0;
 | 
			
		||||
 | 
			
		||||
    wxPanel *panel = new wxPanel( m_notebook, -1 );
 | 
			
		||||
    (void)new wxButton( panel, -1, "Button", wxPoint( 10,10 ), wxSize(-1,-1) );
 | 
			
		||||
 | 
			
		||||
    m_notebook->InsertPage(0, panel, wxString::Format("Inserted %u", ++s_pageIns) );
 | 
			
		||||
    m_notebook->SetSelection(0);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnDeletePage(wxCommandEvent& WXUNUSED(event))
 | 
			
		||||
{
 | 
			
		||||
    m_notebook->DeletePage( m_notebook->GetPageCount()-1 );
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnNextPage(wxCommandEvent& WXUNUSED(event))
 | 
			
		||||
{
 | 
			
		||||
    m_notebook->AdvanceSelection();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnOK(wxCommandEvent& WXUNUSED(event) )
 | 
			
		||||
{
 | 
			
		||||
    Destroy();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnCloseWindow(wxCloseEvent& WXUNUSED(event) )
 | 
			
		||||
{
 | 
			
		||||
    Destroy();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::Init()
 | 
			
		||||
{
 | 
			
		||||
  m_panel = new wxPanel(this, -1, wxDefaultPosition, wxDefaultSize, wxTAB_TRAVERSAL|wxCLIP_CHILDREN);
 | 
			
		||||
 | 
			
		||||
  wxLayoutConstraints* c = new wxLayoutConstraints;
 | 
			
		||||
  c->left.SameAs(this, wxLeft);
 | 
			
		||||
  c->right.SameAs(this, wxRight);
 | 
			
		||||
  c->top.SameAs(this, wxTop);
 | 
			
		||||
  c->bottom.SameAs(this, wxBottom);
 | 
			
		||||
  m_panel->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  m_notebook = new wxNotebook(m_panel, ID_NOTEBOOK);
 | 
			
		||||
 | 
			
		||||
  c = new wxLayoutConstraints;
 | 
			
		||||
  c->left.SameAs(m_panel, wxLeft, 4);
 | 
			
		||||
  c->right.SameAs(m_panel, wxRight, 4);
 | 
			
		||||
  c->top.SameAs(m_panel, wxTop, 4);
 | 
			
		||||
  c->bottom.SameAs(m_panel, wxBottom, 40);
 | 
			
		||||
 | 
			
		||||
  m_notebook->SetConstraints(c);
 | 
			
		||||
 | 
			
		||||
  wxGetApp().InitTabView(m_notebook, m_panel);
 | 
			
		||||
 | 
			
		||||
  m_panel->SetAutoLayout(TRUE);
 | 
			
		||||
  SetAutoLayout(TRUE);
 | 
			
		||||
 | 
			
		||||
  Centre(wxBOTH);
 | 
			
		||||
 | 
			
		||||
  Show(TRUE);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void MyFrame::OnIdle(wxIdleEvent& WXUNUSED(event))
 | 
			
		||||
{
 | 
			
		||||
    static int s_nPages = -1;
 | 
			
		||||
    static int s_nSel = -1;
 | 
			
		||||
 | 
			
		||||
    int nPages = m_notebook->GetPageCount();
 | 
			
		||||
    int nSel = m_notebook->GetSelection();
 | 
			
		||||
    if ( nPages != s_nPages || nSel != s_nSel )
 | 
			
		||||
    {
 | 
			
		||||
        s_nPages = nPages;
 | 
			
		||||
        s_nSel = nSel;
 | 
			
		||||
 | 
			
		||||
        wxString title;
 | 
			
		||||
        title.Printf("Notebook (%d pages, selection: %d)", nPages, nSel);
 | 
			
		||||
 | 
			
		||||
        SetTitle(title);
 | 
			
		||||
    }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#endif // USE_TABBED_DIALOG
 | 
			
		||||
		Reference in New Issue
	
	Block a user