X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/77ba7af1c2252eff7b8d9833d370e08ea1033f3b..789e9abb4527c87ff4503f252c925d247b2480a1:/samples/wizard/wizard.cpp?ds=sidebyside diff --git a/samples/wizard/wizard.cpp b/samples/wizard/wizard.cpp index bba0ef2b18..215f686f85 100644 --- a/samples/wizard/wizard.cpp +++ b/samples/wizard/wizard.cpp @@ -26,6 +26,7 @@ // for all others, include the necessary headers #ifndef WX_PRECOMP + #include "wx/frame.h" #include "wx/stattext.h" #include "wx/log.h" #include "wx/app.h" @@ -37,11 +38,14 @@ #include "wx/sizer.h" #endif +#include "wx/textctrl.h" #include "wx/wizard.h" #include "wiztest.xpm" #include "wiztest2.xpm" +#include "../sample.xpm" + // ---------------------------------------------------------------------------- // constants // ---------------------------------------------------------------------------- @@ -49,9 +53,15 @@ // ids for menu items enum { - Wizard_Quit = 100, - Wizard_Run, - Wizard_About = 1000 + Wizard_About = wxID_ABOUT, + Wizard_Quit = wxID_EXIT, + Wizard_RunModal = wxID_HIGHEST, + + Wizard_RunNoSizer, + Wizard_RunModeless, + + Wizard_LargeWizard, + Wizard_ExpandBitmap }; // ---------------------------------------------------------------------------- @@ -76,6 +86,8 @@ public: void OnQuit(wxCommandEvent& event); void OnAbout(wxCommandEvent& event); void OnRunWizard(wxCommandEvent& event); + void OnRunWizardNoSizer(wxCommandEvent& event); + void OnRunWizardModeless(wxCommandEvent& event); void OnWizardCancel(wxWizardEvent& event); void OnWizardFinished(wxWizardEvent& event); @@ -84,6 +96,21 @@ private: DECLARE_EVENT_TABLE() }; +// ---------------------------------------------------------------------------- +// our wizard +// ---------------------------------------------------------------------------- + +class MyWizard : public wxWizard +{ +public: + MyWizard(wxFrame *frame, bool useSizer = true); + + wxWizardPage *GetFirstPage() const { return m_page1; } + +private: + wxWizardPageSimple *m_page1; +}; + // ---------------------------------------------------------------------------- // some pages for our wizard // ---------------------------------------------------------------------------- @@ -101,13 +128,13 @@ public: { m_bitmap = wxBitmap(wiztest2_xpm); - m_checkbox = new wxCheckBox(this, wxID_ANY, _T("&Check me")); + m_checkbox = new wxCheckBox(this, wxID_ANY, wxT("&Check me")); wxBoxSizer *mainSizer = new wxBoxSizer(wxVERTICAL); mainSizer->Add( new wxStaticText(this, wxID_ANY, - _T("You need to check the checkbox\n") - _T("below before going to the next page\n")), + wxT("You need to check the checkbox\n") + wxT("below before going to the next page\n")), 0, wxALL, 5 @@ -119,15 +146,14 @@ public: wxALL, 5 // Border ); - SetSizer(mainSizer); - mainSizer->Fit(this); + SetSizerAndFit(mainSizer); } virtual bool TransferDataFromWindow() { if ( !m_checkbox->GetValue() ) { - wxMessageBox(_T("Check the checkbox first!"), _T("No way"), + wxMessageBox(wxT("Check the checkbox first!"), wxT("No way"), wxICON_WARNING | wxOK, this); return false; @@ -158,12 +184,12 @@ public: // static wxString choices[] = { "forward", "backward", "both", "neither" }; // The above syntax can cause an internal compiler error with gcc. wxString choices[4]; - choices[0] = _T("forward"); - choices[1] = _T("backward"); - choices[2] = _T("both"); - choices[3] = _T("neither"); + choices[0] = wxT("forward"); + choices[1] = wxT("backward"); + choices[2] = wxT("both"); + choices[3] = wxT("neither"); - m_radio = new wxRadioBox(this, wxID_ANY, _T("Allow to proceed:"), + m_radio = new wxRadioBox(this, wxID_ANY, wxT("Allow to proceed:"), wxDefaultPosition, wxDefaultSize, WXSIZEOF(choices), choices, 1, wxRA_SPECIFY_COLS); @@ -177,14 +203,13 @@ public: 5 // Border ); - SetSizer(mainSizer); - mainSizer->Fit(this); + SetSizerAndFit(mainSizer); } // wizard event handlers void OnWizardCancel(wxWizardEvent& event) { - if ( wxMessageBox(_T("Do you really want to cancel?"), _T("Question"), + if ( wxMessageBox(wxT("Do you really want to cancel?"), wxT("Question"), wxICON_QUESTION | wxYES_NO, this) != wxYES ) { // not confirmed @@ -205,7 +230,7 @@ public: if ( !event.GetDirection() && sel == Backward ) return; - wxMessageBox(_T("You can't go there"), _T("Not allowed"), + wxMessageBox(wxT("You can't go there"), wxT("Not allowed"), wxICON_WARNING | wxOK, this); event.Veto(); @@ -232,14 +257,14 @@ public: wxBoxSizer *mainSizer = new wxBoxSizer(wxVERTICAL); mainSizer->Add( - new wxStaticText(this, wxID_ANY, _T("Try checking the box below and\n") - _T("then going back and clearing it")), + new wxStaticText(this, wxID_ANY, wxT("Try checking the box below and\n") + wxT("then going back and clearing it")), 0, // No vertical stretching wxALL, 5 // Border width ); - m_checkbox = new wxCheckBox(this, wxID_ANY, _T("&Skip the next page")); + m_checkbox = new wxCheckBox(this, wxID_ANY, wxT("&Skip the next page")); mainSizer->Add( m_checkbox, 0, // No vertical stretching @@ -249,14 +274,27 @@ public: #if wxUSE_CHECKLISTBOX static const wxChar *aszChoices[] = - { _T("Zeroth"), _T("First"), _T("Second"), _T("Third"), _T("Fourth"), _T("Fifth"), _T("Sixth"), _T("Seventh"), _T("Eighth"), _T("Nineth") }; - wxString *astrChoices = new wxString[WXSIZEOF(aszChoices)]; - unsigned int ui; - for ( ui = 0; ui < WXSIZEOF(aszChoices); ui++ ) - astrChoices[ui] = aszChoices[ui]; - - m_checklistbox = new wxCheckListBox(this, wxID_ANY, wxDefaultPosition, wxSize(100,100), - WXSIZEOF(aszChoices), astrChoices); + { + wxT("Zeroth"), + wxT("First"), + wxT("Second"), + wxT("Third"), + wxT("Fourth"), + wxT("Fifth"), + wxT("Sixth"), + wxT("Seventh"), + wxT("Eighth"), + wxT("Nineth") + }; + + m_checklistbox = new wxCheckListBox + ( + this, + wxID_ANY, + wxDefaultPosition, + wxSize(100,100), + wxArrayString(WXSIZEOF(aszChoices), aszChoices) + ); mainSizer->Add( m_checklistbox, @@ -266,8 +304,15 @@ public: ); #endif // wxUSE_CHECKLISTBOX - SetSizer(mainSizer); - mainSizer->Fit(this); + wxSize textSize = wxSize(150, 200); + if (((wxFrame*) wxTheApp->GetTopWindow())->GetMenuBar()->IsChecked(Wizard_LargeWizard)) + textSize = wxSize(150, wxGetClientDisplayRect().GetHeight() - 200); + + + wxTextCtrl* textCtrl = new wxTextCtrl(this, wxID_ANY, wxEmptyString, wxDefaultPosition, textSize, wxTE_MULTILINE); + mainSizer->Add(textCtrl, 0, wxALL|wxEXPAND, 5); + + SetSizerAndFit(mainSizer); } // implement wxWizardPage functions @@ -296,11 +341,13 @@ private: // ---------------------------------------------------------------------------- BEGIN_EVENT_TABLE(MyFrame, wxFrame) - EVT_MENU(Wizard_Quit, MyFrame::OnQuit) - EVT_MENU(Wizard_About, MyFrame::OnAbout) - EVT_MENU(Wizard_Run, MyFrame::OnRunWizard) + EVT_MENU(Wizard_Quit, MyFrame::OnQuit) + EVT_MENU(Wizard_About, MyFrame::OnAbout) + EVT_MENU(Wizard_RunModal, MyFrame::OnRunWizard) + EVT_MENU(Wizard_RunNoSizer, MyFrame::OnRunWizardNoSizer) + EVT_MENU(Wizard_RunModeless, MyFrame::OnRunWizardModeless) - EVT_WIZARD_CANCEL(wxID_ANY, MyFrame::OnWizardCancel) + EVT_WIZARD_CANCEL(wxID_ANY, MyFrame::OnWizardCancel) EVT_WIZARD_FINISHED(wxID_ANY, MyFrame::OnWizardFinished) END_EVENT_TABLE() @@ -318,7 +365,10 @@ IMPLEMENT_APP(MyApp) // `Main program' equivalent: the program execution "starts" here bool MyApp::OnInit() { - MyFrame *frame = new MyFrame(_T("wxWizard Sample")); + if ( !wxApp::OnInit() ) + return false; + + MyFrame *frame = new MyFrame(wxT("wxWizard Sample")); // and show it (the frames, unlike simple controls, are not shown when // created initially) @@ -328,26 +378,87 @@ bool MyApp::OnInit() return true; } +// ---------------------------------------------------------------------------- +// MyWizard +// ---------------------------------------------------------------------------- + +MyWizard::MyWizard(wxFrame *frame, bool useSizer) +{ + SetExtraStyle(wxWIZARD_EX_HELPBUTTON); + + Create(frame,wxID_ANY,wxT("Absolutely Useless Wizard"), + wxBitmap(wiztest_xpm),wxDefaultPosition, + wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER); + SetIcon(wxICON(sample)); + + // Allow the bitmap to be expanded to fit the page height + if (frame->GetMenuBar()->IsChecked(Wizard_ExpandBitmap)) + SetBitmapPlacement(wxWIZARD_VALIGN_CENTRE); + + // Enable scrolling adaptation + if (frame->GetMenuBar()->IsChecked(Wizard_LargeWizard)) + SetLayoutAdaptationMode(wxDIALOG_ADAPTATION_MODE_ENABLED); + + // a wizard page may be either an object of predefined class + m_page1 = new wxWizardPageSimple(this); + + /* wxStaticText *text = */ new wxStaticText(m_page1, wxID_ANY, + wxT("This wizard doesn't help you\nto do anything at all.\n") + wxT("\n") + wxT("The next pages will present you\nwith more useless controls."), + wxPoint(5,5) + ); + + // ... or a derived class + wxRadioboxPage *page3 = new wxRadioboxPage(this); + wxValidationPage *page4 = new wxValidationPage(this); + + // set the page order using a convenience function - could also use + // SetNext/Prev directly as below, but Chain() is shorter, avoids the risk + // of an error and can itself be chained, e.g. you could write + // page3.Chain(page4).Chain(page5) and so on. + page3->Chain(page4); + + // this page is not a wxWizardPageSimple, so we use SetNext/Prev to insert + // it into the chain of pages + wxCheckboxPage *page2 = new wxCheckboxPage(this, m_page1, page3); + m_page1->SetNext(page2); + page3->SetPrev(page2); + + if ( useSizer ) + { + // allow the wizard to size itself around the pages + GetPageAreaSizer()->Add(m_page1); + } +} + // ---------------------------------------------------------------------------- // MyFrame // ---------------------------------------------------------------------------- MyFrame::MyFrame(const wxString& title) - : wxFrame((wxFrame *)NULL, wxID_ANY, title, + :wxFrame((wxFrame *)NULL, wxID_ANY, title, wxDefaultPosition, wxSize(250, 150)) // small frame { wxMenu *menuFile = new wxMenu; - menuFile->Append(Wizard_Run, _T("&Run wizard...\tCtrl-R")); + menuFile->Append(Wizard_RunModal, wxT("&Run wizard modal...\tCtrl-R")); + menuFile->Append(Wizard_RunNoSizer, wxT("Run wizard &without sizer...")); + menuFile->Append(Wizard_RunModeless, wxT("Run wizard &modeless...")); menuFile->AppendSeparator(); - menuFile->Append(Wizard_Quit, _T("E&xit\tAlt-X"), _T("Quit this program")); + menuFile->Append(Wizard_Quit, wxT("E&xit\tAlt-X"), wxT("Quit this program")); + + wxMenu *menuOptions = new wxMenu; + menuOptions->AppendCheckItem(Wizard_LargeWizard, wxT("&Scroll Wizard Pages")); + menuOptions->AppendCheckItem(Wizard_ExpandBitmap, wxT("Si&ze Bitmap To Page")); wxMenu *helpMenu = new wxMenu; - helpMenu->Append(Wizard_About, _T("&About...\tF1"), _T("Show about dialog")); + helpMenu->Append(Wizard_About, wxT("&About\tF1"), wxT("Show about dialog")); // now append the freshly created menu to the menu bar... wxMenuBar *menuBar = new wxMenuBar(); - menuBar->Append(menuFile, _T("&File")); - menuBar->Append(helpMenu, _T("&Help")); + menuBar->Append(menuFile, wxT("&File")); + menuBar->Append(menuOptions, wxT("&Options")); + menuBar->Append(helpMenu, wxT("&Help")); // ... and attach this menu bar to the frame SetMenuBar(menuBar); @@ -366,61 +477,38 @@ void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event)) void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) { - wxMessageBox(_T("Demo of wxWizard class\n") - _T("(c) 1999, 2000 Vadim Zeitlin"), - _T("About wxWizard sample"), wxOK | wxICON_INFORMATION, this); + wxMessageBox(wxT("Demo of wxWizard class\n") + wxT("(c) 1999, 2000 Vadim Zeitlin"), + wxT("About wxWizard sample"), wxOK | wxICON_INFORMATION, this); } void MyFrame::OnRunWizard(wxCommandEvent& WXUNUSED(event)) { - wxWizard *wizard = new wxWizard(this, wxID_ANY, - _T("Absolutely Useless Wizard"), - wxBitmap(wiztest_xpm), - wxDefaultPosition, - wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER); - - // a wizard page may be either an object of predefined class - wxWizardPageSimple *page1 = new wxWizardPageSimple(wizard); + MyWizard wizard(this); - /* wxStaticText *text = */ new wxStaticText(page1, wxID_ANY, - _T("This wizard doesn't help you\nto do anything at all.\n") - _T("\n") - _T("The next pages will present you\nwith more useless controls."), - wxPoint(5,5) - ); - - // ... or a derived class - wxRadioboxPage *page3 = new wxRadioboxPage(wizard); - wxValidationPage *page4 = new wxValidationPage(wizard); - - // set the page order using a convenience function - could also use - // SetNext/Prev directly as below - wxWizardPageSimple::Chain(page3, page4); - - // this page is not a wxWizardPageSimple, so we use SetNext/Prev to insert - // it into the chain of pages - wxCheckboxPage *page2 = new wxCheckboxPage(wizard, page1, page3); - page1->SetNext(page2); - page3->SetPrev(page2); + wizard.RunWizard(wizard.GetFirstPage()); +} - // allow the wizard to size itself around the pages - wizard->GetPageAreaSizer()->Add(page1); +void MyFrame::OnRunWizardNoSizer(wxCommandEvent& WXUNUSED(event)) +{ + MyWizard wizard(this, false); - if ( wizard->RunWizard(page1) ) - { - wxMessageBox(_T("The wizard successfully completed"), _T("That's all"), - wxICON_INFORMATION | wxOK); - } + wizard.RunWizard(wizard.GetFirstPage()); +} - wizard->Destroy(); +void MyFrame::OnRunWizardModeless(wxCommandEvent& WXUNUSED(event)) +{ + MyWizard *wizard = new MyWizard(this); + wizard->ShowPage(wizard->GetFirstPage()); + wizard->Show(true); } void MyFrame::OnWizardFinished(wxWizardEvent& WXUNUSED(event)) { - wxLogStatus(this, wxT("The wizard finished successfully.")); + wxMessageBox(wxT("The wizard finished successfully."), wxT("Wizard notification")); } void MyFrame::OnWizardCancel(wxWizardEvent& WXUNUSED(event)) { - wxLogStatus(this, wxT("The wizard was cancelled.")); + wxMessageBox(wxT("The wizard was cancelled."), wxT("Wizard notification")); }