Possibility of modeless wxWizard dialog (with presentation in sample).
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@34858 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -13,6 +13,7 @@ All:
|
|||||||
All (GUI):
|
All (GUI):
|
||||||
|
|
||||||
- Added wxXmlResource::Unload()
|
- Added wxXmlResource::Unload()
|
||||||
|
- Possibility of modeless wxWizard dialog (with presentation in sample).
|
||||||
|
|
||||||
wxMSW:
|
wxMSW:
|
||||||
|
|
||||||
|
@@ -86,8 +86,10 @@ private:
|
|||||||
void AddBackNextPair(wxBoxSizer *buttonRow);
|
void AddBackNextPair(wxBoxSizer *buttonRow);
|
||||||
void AddButtonRow(wxBoxSizer *mainColumn);
|
void AddButtonRow(wxBoxSizer *mainColumn);
|
||||||
|
|
||||||
|
protected:
|
||||||
void FinishLayout();
|
void FinishLayout();
|
||||||
|
|
||||||
|
private:
|
||||||
wxSize GetManualPageSize() const;
|
wxSize GetManualPageSize() const;
|
||||||
|
|
||||||
// the page size requested by user
|
// the page size requested by user
|
||||||
|
@@ -49,9 +49,10 @@
|
|||||||
// ids for menu items
|
// ids for menu items
|
||||||
enum
|
enum
|
||||||
{
|
{
|
||||||
Wizard_Quit = 100,
|
Wizard_Quit = wxID_EXIT,
|
||||||
Wizard_Run,
|
Wizard_RunModal = wxID_HIGHEST,
|
||||||
Wizard_About = 1000
|
Wizard_RunModeless,
|
||||||
|
Wizard_About = wxID_ABOUT
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -84,6 +85,20 @@ private:
|
|||||||
DECLARE_EVENT_TABLE()
|
DECLARE_EVENT_TABLE()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// our wizard
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class MyWizard : public wxWizard
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
MyWizard(wxFrame *frame);
|
||||||
|
void RunIt(bool modal);
|
||||||
|
|
||||||
|
private:
|
||||||
|
wxWizardPageSimple *m_page1;
|
||||||
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// some pages for our wizard
|
// some pages for our wizard
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -298,7 +313,8 @@ private:
|
|||||||
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
BEGIN_EVENT_TABLE(MyFrame, wxFrame)
|
||||||
EVT_MENU(Wizard_Quit, MyFrame::OnQuit)
|
EVT_MENU(Wizard_Quit, MyFrame::OnQuit)
|
||||||
EVT_MENU(Wizard_About, MyFrame::OnAbout)
|
EVT_MENU(Wizard_About, MyFrame::OnAbout)
|
||||||
EVT_MENU(Wizard_Run, MyFrame::OnRunWizard)
|
EVT_MENU(Wizard_RunModal, MyFrame::OnRunWizard)
|
||||||
|
EVT_MENU(Wizard_RunModeless, MyFrame::OnRunWizard)
|
||||||
|
|
||||||
EVT_WIZARD_CANCEL(wxID_ANY, MyFrame::OnWizardCancel)
|
EVT_WIZARD_CANCEL(wxID_ANY, MyFrame::OnWizardCancel)
|
||||||
EVT_WIZARD_FINISHED(wxID_ANY, MyFrame::OnWizardFinished)
|
EVT_WIZARD_FINISHED(wxID_ANY, MyFrame::OnWizardFinished)
|
||||||
@@ -328,16 +344,74 @@ bool MyApp::OnInit()
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// MyWizard
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
MyWizard::MyWizard(wxFrame *frame)
|
||||||
|
: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);
|
||||||
|
|
||||||
|
// allow the wizard to size itself around the pages
|
||||||
|
GetPageAreaSizer()->Add(m_page1);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MyWizard::RunIt(bool modal)
|
||||||
|
{
|
||||||
|
if ( modal )
|
||||||
|
{
|
||||||
|
if ( RunWizard(m_page1) )
|
||||||
|
{
|
||||||
|
wxMessageBox(_T("The wizard successfully completed"), _T("That's all"),
|
||||||
|
wxICON_INFORMATION | wxOK);
|
||||||
|
}
|
||||||
|
|
||||||
|
Destroy();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
FinishLayout();
|
||||||
|
ShowPage(m_page1);
|
||||||
|
Show(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// MyFrame
|
// MyFrame
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
MyFrame::MyFrame(const wxString& title)
|
MyFrame::MyFrame(const wxString& title)
|
||||||
: wxFrame((wxFrame *)NULL, wxID_ANY, title,
|
:wxFrame((wxFrame *)NULL, wxID_ANY, title,
|
||||||
wxDefaultPosition, wxSize(250, 150)) // small frame
|
wxDefaultPosition, wxSize(250, 150)) // small frame
|
||||||
{
|
{
|
||||||
wxMenu *menuFile = new wxMenu;
|
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_RunModeless, _T("&Run wizard modeless..."));
|
||||||
menuFile->AppendSeparator();
|
menuFile->AppendSeparator();
|
||||||
menuFile->Append(Wizard_Quit, _T("E&xit\tAlt-X"), _T("Quit this program"));
|
menuFile->Append(Wizard_Quit, _T("E&xit\tAlt-X"), _T("Quit this program"));
|
||||||
|
|
||||||
@@ -371,56 +445,19 @@ void MyFrame::OnAbout(wxCommandEvent& WXUNUSED(event))
|
|||||||
_T("About wxWizard sample"), wxOK | wxICON_INFORMATION, this);
|
_T("About wxWizard sample"), wxOK | wxICON_INFORMATION, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::OnRunWizard(wxCommandEvent& WXUNUSED(event))
|
void MyFrame::OnRunWizard(wxCommandEvent& event)
|
||||||
{
|
{
|
||||||
wxWizard *wizard = new wxWizard(this, wxID_ANY,
|
MyWizard *wizard = new MyWizard(this);
|
||||||
_T("Absolutely Useless Wizard"),
|
|
||||||
wxBitmap(wiztest_xpm),
|
|
||||||
wxDefaultPosition,
|
|
||||||
wxDEFAULT_DIALOG_STYLE | wxRESIZE_BORDER);
|
|
||||||
|
|
||||||
// a wizard page may be either an object of predefined class
|
wizard->RunIt( event.GetId() == Wizard_RunModal );
|
||||||
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)
|
|
||||||
);
|
|
||||||
|
|
||||||
// ... 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);
|
|
||||||
|
|
||||||
// allow the wizard to size itself around the pages
|
|
||||||
wizard->GetPageAreaSizer()->Add(page1);
|
|
||||||
|
|
||||||
if ( wizard->RunWizard(page1) )
|
|
||||||
{
|
|
||||||
wxMessageBox(_T("The wizard successfully completed"), _T("That's all"),
|
|
||||||
wxICON_INFORMATION | wxOK);
|
|
||||||
}
|
|
||||||
|
|
||||||
wizard->Destroy();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void MyFrame::OnWizardFinished(wxWizardEvent& WXUNUSED(event))
|
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))
|
void MyFrame::OnWizardCancel(wxWizardEvent& WXUNUSED(event))
|
||||||
{
|
{
|
||||||
wxLogStatus(this, wxT("The wizard was cancelled."));
|
wxMessageBox(wxT("The wizard was cancelled."), wxT("Wizard notification"));
|
||||||
}
|
}
|
||||||
|
@@ -480,6 +480,9 @@ void wxWizard::SetPageSize(const wxSize& size)
|
|||||||
|
|
||||||
void wxWizard::FinishLayout()
|
void wxWizard::FinishLayout()
|
||||||
{
|
{
|
||||||
|
// Set to enable wxWizardSizer::GetMaxChildSize
|
||||||
|
m_started = true;
|
||||||
|
|
||||||
m_sizerBmpAndPage->Add(
|
m_sizerBmpAndPage->Add(
|
||||||
m_sizerPage,
|
m_sizerPage,
|
||||||
1, // Horizontal stretching
|
1, // Horizontal stretching
|
||||||
@@ -555,7 +558,15 @@ bool wxWizard::ShowPage(wxWizardPage *page, bool goingForward)
|
|||||||
if ( !m_page )
|
if ( !m_page )
|
||||||
{
|
{
|
||||||
// terminate successfully
|
// terminate successfully
|
||||||
|
if(IsModal())
|
||||||
|
{
|
||||||
EndModal(wxID_OK);
|
EndModal(wxID_OK);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SetReturnCode(wxID_OK);
|
||||||
|
Hide();
|
||||||
|
}
|
||||||
|
|
||||||
// and notify the user code (this is especially useful for modeless
|
// and notify the user code (this is especially useful for modeless
|
||||||
// wizards)
|
// wizards)
|
||||||
@@ -625,9 +636,6 @@ bool wxWizard::RunWizard(wxWizardPage *firstPage)
|
|||||||
{
|
{
|
||||||
wxCHECK_MSG( firstPage, false, wxT("can't run empty wizard") );
|
wxCHECK_MSG( firstPage, false, wxT("can't run empty wizard") );
|
||||||
|
|
||||||
// Set before FinishLayout to enable wxWizardSizer::GetMaxChildSize
|
|
||||||
m_started = true;
|
|
||||||
|
|
||||||
// This cannot be done sooner, because user can change layout options
|
// This cannot be done sooner, because user can change layout options
|
||||||
// up to this moment
|
// up to this moment
|
||||||
FinishLayout();
|
FinishLayout();
|
||||||
@@ -695,8 +703,16 @@ void wxWizard::OnCancel(wxCommandEvent& WXUNUSED(eventUnused))
|
|||||||
if ( !win->GetEventHandler()->ProcessEvent(event) || event.IsAllowed() )
|
if ( !win->GetEventHandler()->ProcessEvent(event) || event.IsAllowed() )
|
||||||
{
|
{
|
||||||
// no objections - close the dialog
|
// no objections - close the dialog
|
||||||
|
if(IsModal())
|
||||||
|
{
|
||||||
EndModal(wxID_CANCEL);
|
EndModal(wxID_CANCEL);
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
SetReturnCode(wxID_CANCEL);
|
||||||
|
Hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
//else: request to Cancel ignored
|
//else: request to Cancel ignored
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -755,15 +771,26 @@ void wxWizard::OnWizEvent(wxWizardEvent& event)
|
|||||||
{
|
{
|
||||||
// the event will be propagated anyhow
|
// the event will be propagated anyhow
|
||||||
event.Skip();
|
event.Skip();
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
wxWindow *parent = GetParent();
|
wxWindow *parent = GetParent();
|
||||||
|
|
||||||
if ( !parent || !parent->GetEventHandler()->ProcessEvent(event) )
|
if ( !parent || !parent->GetEventHandler()->ProcessEvent(event) )
|
||||||
{
|
{
|
||||||
event.Skip();
|
event.Skip();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if ( !IsModal() &&
|
||||||
|
event.IsAllowed() &&
|
||||||
|
( event.GetEventType() == wxEVT_WIZARD_FINISHED ||
|
||||||
|
event.GetEventType() == wxEVT_WIZARD_CANCEL
|
||||||
|
)
|
||||||
|
)
|
||||||
|
{
|
||||||
|
Destroy();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -17,6 +17,7 @@
|
|||||||
wxEVT_SCROLL_CHANGED;
|
wxEVT_SCROLL_CHANGED;
|
||||||
*wxFileDialog*DoSetSize*;
|
*wxFileDialog*DoSetSize*;
|
||||||
*wxDialog*GetEscapeId*;
|
*wxDialog*GetEscapeId*;
|
||||||
|
*wxWizard*FinishLayout*;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user