// 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"
{
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);
class MyWizard : public wxWizard
{
public:
- MyWizard(wxFrame *frame);
- void RunIt(bool modal);
+ MyWizard(wxFrame *frame, bool useSizer = true);
+
+ wxWizardPage *GetFirstPage() const { return m_page1; }
private:
wxWizardPageSimple *m_page1;
EVT_MENU(Wizard_Quit, MyFrame::OnQuit)
EVT_MENU(Wizard_About, MyFrame::OnAbout)
EVT_MENU(Wizard_RunModal, MyFrame::OnRunWizard)
- EVT_MENU(Wizard_RunModeless, MyFrame::OnRunWizard)
+ EVT_MENU(Wizard_RunNoSizer, MyFrame::OnRunWizardNoSizer)
+ EVT_MENU(Wizard_RunModeless, MyFrame::OnRunWizardModeless)
EVT_WIZARD_CANCEL(wxID_ANY, MyFrame::OnWizardCancel)
EVT_WIZARD_FINISHED(wxID_ANY, MyFrame::OnWizardFinished)
// MyWizard
// ----------------------------------------------------------------------------
-MyWizard::MyWizard(wxFrame *frame)
- :wxWizard(frame,wxID_ANY,_T("Absolutely Useless Wizard"),
+MyWizard::MyWizard(wxFrame *frame, bool useSizer)
+ : wxWizard(frame,wxID_ANY,_T("Absolutely Useless Wizard"),
wxBitmap(wiztest_xpm),wxDefaultPosition,
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER)
{
m_page1->SetNext(page2);
page3->SetPrev(page2);
- // allow the wizard to size itself around the pages
- GetPageAreaSizer()->Add(m_page1);
-}
-
-void MyWizard::RunIt(bool modal)
-{
- if ( modal )
- {
- if ( RunWizard(m_page1) )
- {
- // Success
- }
-
- Destroy();
- }
- else
+ if ( useSizer )
{
- FinishLayout();
- ShowPage(m_page1);
- Show(true);
+ // allow the wizard to size itself around the pages
+ GetPageAreaSizer()->Add(m_page1);
}
}
{
wxMenu *menuFile = new wxMenu;
menuFile->Append(Wizard_RunModal, _T("&Run wizard modal...\tCtrl-R"));
- menuFile->Append(Wizard_RunModeless, _T("&Run wizard modeless..."));
+ 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"));
_T("About wxWizard sample"), wxOK | wxICON_INFORMATION, this);
}
-void MyFrame::OnRunWizard(wxCommandEvent& event)
+void MyFrame::OnRunWizard(wxCommandEvent& WXUNUSED(event))
{
- MyWizard *wizard = new MyWizard(this);
+ MyWizard wizard(this);
+
+ wizard.RunWizard(wizard.GetFirstPage());
+}
+
+void MyFrame::OnRunWizardNoSizer(wxCommandEvent& WXUNUSED(event))
+{
+ MyWizard wizard(this, false);
- wizard->RunIt( event.GetId() == Wizard_RunModal );
+ wizard.RunWizard(wizard.GetFirstPage());
+}
+
+void MyFrame::OnRunWizardModeless(wxCommandEvent& WXUNUSED(event))
+{
+ MyWizard *wizard = new MyWizard(this);
+ wizard->ShowPage(wizard->GetFirstPage());
+ wizard->Show(true);
}
void MyFrame::OnWizardFinished(wxWizardEvent& WXUNUSED(event))