// 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"
#include "wx/checkbox.h"
+ #include "wx/checklst.h"
#include "wx/msgdlg.h"
#include "wx/radiobox.h"
#include "wx/menu.h"
#include "wx/wizard.h"
-#ifndef __WXMSW__
- #include "wiztest.xpm"
- #include "wiztest2.xpm"
-#endif
+#include "wiztest.xpm"
+#include "wiztest2.xpm"
// ----------------------------------------------------------------------------
// constants
// ids for menu items
enum
{
- Wizard_Quit = 100,
- Wizard_Run,
- Wizard_About = 1000
+ Wizard_Quit = wxID_EXIT,
+ Wizard_RunModal = wxID_HIGHEST,
+ Wizard_RunNoSizer,
+ Wizard_RunModeless,
+ Wizard_About = wxID_ABOUT
};
// ----------------------------------------------------------------------------
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);
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
// ----------------------------------------------------------------------------
-// this shows how to simply control the validity of the user input by just
+// This shows how to simply control the validity of the user input by just
// overriding TransferDataFromWindow() - of course, in a real program, the
// check wouldn't be so trivial and the data will be probably saved somewhere
-// too
+// too.
//
-// it also shows how to use a different bitmap for one of the pages
+// It also shows how to use a different bitmap for one of the pages.
class wxValidationPage : public wxWizardPageSimple
{
public:
wxValidationPage(wxWizard *parent) : wxWizardPageSimple(parent)
{
- m_bitmap = wxBITMAP(wiztest2);
+ m_bitmap = wxBitmap(wiztest2_xpm);
m_checkbox = new wxCheckBox(this, wxID_ANY, _T("&Check me"));
-
+
wxBoxSizer *mainSizer = new wxBoxSizer(wxVERTICAL);
mainSizer->Add(
new wxStaticText(this, wxID_ANY,
WXSIZEOF(choices), choices,
1, wxRA_SPECIFY_COLS);
m_radio->SetSelection(Both);
-
+
wxBoxSizer *mainSizer = new wxBoxSizer(wxVERTICAL);
mainSizer->Add(
m_radio,
wxALL,
5 // Border
);
+
SetSizer(mainSizer);
mainSizer->Fit(this);
}
DECLARE_EVENT_TABLE()
};
-// this shows how to dynamically (i.e. during run-time) arrange the page order
+// This shows how to dynamically (i.e. during run-time) arrange the page order.
class wxCheckboxPage : public wxWizardPage
{
public:
{
m_prev = prev;
m_next = next;
-
+
wxBoxSizer *mainSizer = new wxBoxSizer(wxVERTICAL);
mainSizer->Add(
wxALL,
5 // Border width
);
-
+
+#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")
+ };
+
+ m_checklistbox = new wxCheckListBox
+ (
+ this,
+ wxID_ANY,
+ wxDefaultPosition,
+ wxSize(100,100),
+ wxArrayString(WXSIZEOF(aszChoices), aszChoices)
+ );
+
+ mainSizer->Add(
+ m_checklistbox,
+ 0, // No vertical stretching
+ wxALL,
+ 5 // Border width
+ );
+#endif // wxUSE_CHECKLISTBOX
+
SetSizer(mainSizer);
mainSizer->Fit(this);
}
*m_next;
wxCheckBox *m_checkbox;
+#if wxUSE_CHECKLISTBOX
+ wxCheckListBox *m_checklistbox;
+#endif
};
// ============================================================================
// ----------------------------------------------------------------------------
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()
return true;
}
+// ----------------------------------------------------------------------------
+// MyWizard
+// ----------------------------------------------------------------------------
+
+MyWizard::MyWizard(wxFrame *frame, bool useSizer)
+ : wxWizard(frame,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
+ m_page1 = new wxWizardPageSimple(this);
+
+ /* wxStaticText *text = */ new wxStaticText(m_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(this);
+ wxValidationPage *page4 = new wxValidationPage(this);
+
+ // 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(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, _T("&Run wizard modal...\tCtrl-R"));
+ menuFile->Append(Wizard_RunNoSizer, _T("Run wizard &without sizer..."));
+ menuFile->Append(Wizard_RunModeless, _T("Run wizard &modeless..."));
menuFile->AppendSeparator();
menuFile->Append(Wizard_Quit, _T("E&xit\tAlt-X"), _T("Quit this program"));
SetMenuBar(menuBar);
// also create status bar which we use in OnWizardCancel
+#if wxUSE_STATUSBAR
CreateStatusBar();
+#endif // wxUSE_STATUSBAR
}
void MyFrame::OnQuit(wxCommandEvent& WXUNUSED(event))
void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
{
wxMessageBox(_T("Demo of wxWizard class\n")
- _T("© 1999, 2000 Vadim Zeitlin"),
+ _T("(c) 1999, 2000 Vadim Zeitlin"),
_T("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),
- wxDefaultPosition,
- wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER);
-
- // a wizard page may be either an object of predefined class
- wxWizardPageSimple *page1 = new wxWizardPageSimple(wizard);
- 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)
- );
- wxSize size = text->GetBestSize();
+ MyWizard wizard(this);
- // ... 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);
+ wizard.RunWizard(wizard.GetFirstPage());
+}
- // 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);
+void MyFrame::OnRunWizardNoSizer(wxCommandEvent& WXUNUSED(event))
+{
+ MyWizard wizard(this, false);
- wizard->SetPageSize(size);
- wizard->GetPageAreaSizer()->Add(page1);
-
- 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"));
}