git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@40727 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
		
			
				
	
	
		
			245 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			245 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| 
 | |
| import  wx
 | |
| import  wx.wizard as wiz
 | |
| import  images
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| def makePageTitle(wizPg, title):
 | |
|     sizer = wx.BoxSizer(wx.VERTICAL)
 | |
|     wizPg.SetSizer(sizer)
 | |
|     title = wx.StaticText(wizPg, -1, title)
 | |
|     title.SetFont(wx.Font(18, wx.SWISS, wx.NORMAL, wx.BOLD))
 | |
|     sizer.Add(title, 0, wx.ALIGN_CENTRE|wx.ALL, 5)
 | |
|     sizer.Add(wx.StaticLine(wizPg, -1), 0, wx.EXPAND|wx.ALL, 5)
 | |
|     return sizer
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| class TitledPage(wiz.WizardPageSimple):
 | |
|     def __init__(self, parent, title):
 | |
|         wiz.WizardPageSimple.__init__(self, parent)
 | |
|         self.sizer = makePageTitle(self, title)
 | |
| 
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| class SkipNextPage(wiz.PyWizardPage):
 | |
|     def __init__(self, parent, title):
 | |
|         wiz.PyWizardPage.__init__(self, parent)
 | |
|         self.next = self.prev = None
 | |
|         self.sizer = makePageTitle(self, title)
 | |
| 
 | |
|         self.cb = wx.CheckBox(self, -1, "Skip next page")
 | |
|         self.sizer.Add(self.cb, 0, wx.ALL, 5)
 | |
| 
 | |
|     def SetNext(self, next):
 | |
|         self.next = next
 | |
| 
 | |
|     def SetPrev(self, prev):
 | |
|         self.prev = prev
 | |
| 
 | |
| 
 | |
|     # Classes derived from wxPyWizardPanel must override
 | |
|     # GetNext and GetPrev, and may also override GetBitmap
 | |
|     # as well as all those methods overridable by
 | |
|     # wx.PyWindow.
 | |
| 
 | |
|     def GetNext(self):
 | |
|         """If the checkbox is set then return the next page's next page"""
 | |
|         next = self.next
 | |
|         if self.cb.GetValue():
 | |
|             next = next.GetNext()
 | |
|         return next
 | |
| 
 | |
|     def GetPrev(self):
 | |
|         return self.prev
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| class UseAltBitmapPage(wiz.PyWizardPage):
 | |
|     def __init__(self, parent, title):
 | |
|         wiz.PyWizardPage.__init__(self, parent)
 | |
|         self.next = self.prev = None
 | |
|         self.sizer = makePageTitle(self, title)
 | |
| 
 | |
|         self.sizer.Add(wx.StaticText(self, -1, "This page uses a different bitmap"),
 | |
|                        0, wx.ALL, 5)
 | |
| 
 | |
|     def SetNext(self, next):
 | |
|         self.next = next
 | |
| 
 | |
|     def SetPrev(self, prev):
 | |
|         self.prev = prev
 | |
| 
 | |
|     def GetNext(self):
 | |
|         return self.next
 | |
| 
 | |
|     def GetPrev(self):
 | |
|         return self.prev
 | |
| 
 | |
|     def GetBitmap(self):
 | |
|         # You usually wouldn't need to override this method
 | |
|         # since you can set a non-default bitmap in the
 | |
|         # wxWizardPageSimple constructor, but if you need to
 | |
|         # dynamically change the bitmap based on the
 | |
|         # contents of the wizard, or need to also change the
 | |
|         # next/prev order then it can be done by overriding
 | |
|         # GetBitmap.
 | |
|         return images.getWizTest2Bitmap()
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| class TestPanel(wx.Panel):
 | |
|     def __init__(self, parent, log):
 | |
|         self.log = log
 | |
|         wx.Panel.__init__(self, parent, -1)
 | |
| 
 | |
|         b = wx.Button(self, -1, "Run Simple Wizard", pos=(50, 50))
 | |
|         self.Bind(wx.EVT_BUTTON, self.OnRunSimpleWizard, b)
 | |
| 
 | |
|         b = wx.Button(self, -1, "Run Dynamic Wizard", pos=(50, 100))
 | |
|         self.Bind(wx.EVT_BUTTON, self.OnRunDynamicWizard, b)
 | |
| 
 | |
|         self.Bind(wiz.EVT_WIZARD_PAGE_CHANGED, self.OnWizPageChanged)
 | |
|         self.Bind(wiz.EVT_WIZARD_PAGE_CHANGING, self.OnWizPageChanging)
 | |
|         self.Bind(wiz.EVT_WIZARD_CANCEL, self.OnWizCancel)
 | |
| 
 | |
| 
 | |
|     def OnWizPageChanged(self, evt):
 | |
|         if evt.GetDirection():
 | |
|             dir = "forward"
 | |
|         else:
 | |
|             dir = "backward"
 | |
| 
 | |
|         page = evt.GetPage()
 | |
|         self.log.write("OnWizPageChanged: %s, %s\n" % (dir, page.__class__))
 | |
| 
 | |
| 
 | |
|     def OnWizPageChanging(self, evt):
 | |
|         if evt.GetDirection():
 | |
|             dir = "forward"
 | |
|         else:
 | |
|             dir = "backward"
 | |
| 
 | |
|         page = evt.GetPage()
 | |
|         self.log.write("OnWizPageChanging: %s, %s\n" % (dir, page.__class__))
 | |
| 
 | |
| 
 | |
|     def OnWizCancel(self, evt):
 | |
|         page = evt.GetPage()
 | |
|         self.log.write("OnWizCancel: %s\n" % page.__class__)
 | |
| 
 | |
|         # Show how to prevent cancelling of the wizard.  The
 | |
|         # other events can be Veto'd too.
 | |
|         if page is self.page1:
 | |
|             wx.MessageBox("Cancelling on the first page has been prevented.", "Sorry")
 | |
|             evt.Veto()
 | |
| 
 | |
| 
 | |
|     def OnWizFinished(self, evt):
 | |
|         self.log.write("OnWizFinished\n")
 | |
|         
 | |
| 
 | |
|     def OnRunSimpleWizard(self, evt):
 | |
|         # Create the wizard and the pages
 | |
|         wizard = wiz.Wizard(self, -1, "Simple Wizard", images.getWizTest1Bitmap())
 | |
|         page1 = TitledPage(wizard, "Page 1")
 | |
|         page2 = TitledPage(wizard, "Page 2")
 | |
|         page3 = TitledPage(wizard, "Page 3")
 | |
|         page4 = TitledPage(wizard, "Page 4")
 | |
|         self.page1 = page1
 | |
| 
 | |
|         page1.sizer.Add(wx.StaticText(page1, -1, """
 | |
| This wizard is totally useless, but is meant to show how to
 | |
| chain simple wizard pages together in a non-dynamic manner.
 | |
| IOW, the order of the pages never changes, and so the
 | |
| wxWizardPageSimple class can easily be used for the pages."""))
 | |
|         wizard.FitToPage(page1)
 | |
|         page4.sizer.Add(wx.StaticText(page4, -1, "\nThis is the last page."))
 | |
| 
 | |
|         # Use the convenience Chain function to connect the pages
 | |
|         wiz.WizardPageSimple_Chain(page1, page2)
 | |
|         wiz.WizardPageSimple_Chain(page2, page3)
 | |
|         wiz.WizardPageSimple_Chain(page3, page4)
 | |
| 
 | |
|         wizard.GetPageAreaSizer().Add(page1)
 | |
|         if wizard.RunWizard(page1):
 | |
|             wx.MessageBox("Wizard completed successfully", "That's all folks!")
 | |
|         else:
 | |
|             wx.MessageBox("Wizard was cancelled", "That's all folks!")
 | |
| 
 | |
| 
 | |
| 
 | |
|     def OnRunDynamicWizard(self, evt):
 | |
|         # Create the wizard and the pages
 | |
|         #wizard = wx.PreWizard()
 | |
|         #wizard.SetExtraStyle(wx.WIZARD_EX_HELPBUTTON)
 | |
|         #wizard.Create(self, self.ID_wiz, "Simple Wizard",
 | |
|         #              images.getWizTest1Bitmap())
 | |
|         wizard = wiz.Wizard(self, -1, "Dynamic Wizard", images.getWizTest1Bitmap())
 | |
| 
 | |
|         page1 = TitledPage(wizard, "Page 1")
 | |
|         page2 = SkipNextPage(wizard, "Page 2")
 | |
|         page3 = TitledPage(wizard, "Page 3")
 | |
|         page4 = UseAltBitmapPage(wizard, "Page 4")
 | |
|         page5 = TitledPage(wizard, "Page 5")
 | |
|         self.page1 = page1
 | |
| 
 | |
|         page1.sizer.Add(wx.StaticText(page1, -1, """
 | |
| This wizard shows the ability to choose at runtime the order
 | |
| of the pages and also which bitmap is shown.
 | |
| """))
 | |
|         wizard.FitToPage(page1)
 | |
|         page5.sizer.Add(wx.StaticText(page5, -1, "\nThis is the last page."))
 | |
| 
 | |
|         # Set the initial order of the pages
 | |
|         page1.SetNext(page2)
 | |
|         page2.SetPrev(page1)
 | |
|         page2.SetNext(page3)
 | |
|         page3.SetPrev(page2)
 | |
|         page3.SetNext(page4)
 | |
|         page4.SetPrev(page3)
 | |
|         page4.SetNext(page5)
 | |
|         page5.SetPrev(page4)
 | |
| 
 | |
| 
 | |
|         wizard.GetPageAreaSizer().Add(page1)
 | |
|         if wizard.RunWizard(page1):
 | |
|             wx.MessageBox("Wizard completed successfully", "That's all folks!")
 | |
|         else:
 | |
|             wx.MessageBox("Wizard was cancelled", "That's all folks!")
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| def runTest(frame, nb, log):
 | |
|     win = TestPanel(nb, log)
 | |
|     return win
 | |
| 
 | |
| #----------------------------------------------------------------------
 | |
| 
 | |
| 
 | |
| 
 | |
| overview = """<html><body>
 | |
| <h2><center>wxWizard</center></h2>
 | |
| 
 | |
| wxWizard is the central class for implementing 'wizard-like'
 | |
| dialogs. These dialogs are mostly familiar to Windows users and are
 | |
| nothing else but a sequence of 'pages' each of them displayed inside a
 | |
| dialog which has the buttons to pass to the next (and previous) pages.
 | |
| <p>
 | |
| The wizards are typically used to decompose a complex dialog into
 | |
| several simple steps and are mainly useful to the novice users, hence
 | |
| it is important to keep them as simple as possible.
 | |
| 
 | |
| </body></html>
 | |
| """
 | |
| 
 | |
| 
 | |
| 
 | |
| if __name__ == '__main__':
 | |
|     import sys,os
 | |
|     import run
 | |
|     run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
 | |
| 
 |