2 #----------------------------------------------------------------------------
4 # Purpose: Testing lots of stuff, controls, window types, etc.
8 # Created: A long time ago, in a galaxy far, far away...
10 # Copyright: (c) 1999 by Total Control Software
11 # Licence: wxWindows license
12 #----------------------------------------------------------------------------
16 import wx
# This module uses the new wx namespace
23 ##print "wx.VERSION_STRING = ", wx.VERSION_STRING
25 ##raw_input("Press Enter...")
28 #---------------------------------------------------------------------------
33 ('Recent Additions', [
38 'XmlResourceSubclass',
43 'ActiveX_FlashWindow',
44 'ActiveX_IEHtmlWindow',
48 # managed windows == things with a (optional) caption you can close
49 ('Base Frames and Dialogs', [
73 # dialogs from libraries
76 'MultipleChoiceDialog',
77 'ScrolledMessageDialog',
81 ('Core Windows/Controls', [
117 ('Custom Controls', [
130 # controls coming from other libraries
131 ('More Windows/Controls', [
132 'ActiveX_FlashWindow',
133 'ActiveX_IEHtmlWindow',
135 #'RightTextCtrl', deprecated as we have wxTE_RIGHT now.
148 'MaskedEditControls',
164 # How to lay out the controls in a frame/dialog
174 'XmlResourceHandler',
175 'XmlResourceSubclass',
179 ('Process and Events', [
190 ('Clipboard and DnD', [
223 # need libs not coming with the demo
224 ('Objects using an external library', [
229 ('Check out the samples dir too', [
236 #---------------------------------------------------------------------------
237 # Show how to derive a custom wxLog class
239 class MyLog(wx
.PyLog
):
240 def __init__(self
, textCtrl
, logTime
=0):
241 wx
.PyLog
.__init
__(self
)
243 self
.logTime
= logTime
245 def DoLogString(self
, message
, timeStamp
):
247 message
= time
.strftime("%X", time
.localtime(timeStamp
)) + \
250 self
.tc
.AppendText(message
+ '\n')
253 class MyTP(wx
.PyTipProvider
):
255 return "This is my tip"
257 #---------------------------------------------------------------------------
258 # A class to be used to display source code in the demo. Try using the
259 # wxSTC in the StyledTextCtrl_2 sample first, fall back to wxTextCtrl
260 # if there is an error, such as the stc module not being present.
266 from StyledTextCtrl_2
import PythonSTC
267 class DemoCodeViewer(PythonSTC
):
268 def __init__(self
, parent
, ID
):
269 PythonSTC
.__init
__(self
, parent
, ID
, wx
.BORDER_NONE
)
272 # Some methods to make it compatible with how the wxTextCtrl is used
273 def SetValue(self
, value
):
274 self
.SetReadOnly(False)
276 self
.SetReadOnly(True)
281 def SetInsertionPoint(self
, pos
):
282 self
.SetCurrentPos(pos
)
284 def ShowPosition(self
, pos
):
287 def GetLastPosition(self
):
288 return self
.GetLength()
290 def GetRange(self
, start
, end
):
291 return self
.GetTextRange(start
, end
)
293 def GetSelection(self
):
294 return self
.GetAnchor(), self
.GetCurrentPos()
296 def SetSelection(self
, start
, end
):
297 self
.SetSelectionStart(start
)
298 self
.SetSelectionEnd(end
)
300 def SetUpEditor(self
):
302 This method carries out the work of setting up the demo editor.
303 It's seperate so as not to clutter up the init code.
307 self
.SetLexer(stc
.STC_LEX_PYTHON
)
308 self
.SetKeyWords(0, " ".join(keyword
.kwlist
))
311 self
.SetProperty("fold", "1" )
313 # Highlight tab/space mixing (shouldn't be any)
314 self
.SetProperty("tab.timmy.whinge.level", "1")
316 # Set left and right margins
319 # Set up the numbers in the margin for margin #1
320 self
.SetMarginType(1, wx
.stc
.STC_MARGIN_NUMBER
)
321 # Reasonable value for, say, 4-5 digits using a mono font (40 pix)
322 self
.SetMarginWidth(1, 40)
324 # Indentation and tab stuff
325 self
.SetIndent(4) # Proscribed indent size for wx
326 self
.SetIndentationGuides(True) # Show indent guides
327 self
.SetBackSpaceUnIndents(True)# Backspace unindents rather than delete 1 space
328 self
.SetTabIndents(True) # Tab key indents
329 self
.SetTabWidth(4) # Proscribed tab size for wx
330 self
.SetUseTabs(False) # Use spaces rather than tabs, or
331 # TabTimmy will complain!
333 self
.SetViewWhiteSpace(False) # Don't view white space
336 #self.SetEOLMode(wx.stc.STC_EOL_CRLF) # Just leave it at the default (autosense)
337 self
.SetViewEOL(False)
338 # No right-edge mode indicator
339 self
.SetEdgeMode(stc
.STC_EDGE_NONE
)
341 # Setup a margin to hold fold markers
342 self
.SetMarginType(2, stc
.STC_MARGIN_SYMBOL
)
343 self
.SetMarginMask(2, stc
.STC_MASK_FOLDERS
)
344 self
.SetMarginSensitive(2, True)
345 self
.SetMarginWidth(2, 12)
347 # and now set up the fold markers
348 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDEREND
, stc
.STC_MARK_BOXPLUSCONNECTED
, "white", "black")
349 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDEROPENMID
, stc
.STC_MARK_BOXMINUSCONNECTED
, "white", "black")
350 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDERMIDTAIL
, stc
.STC_MARK_TCORNER
, "white", "black")
351 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDERTAIL
, stc
.STC_MARK_LCORNER
, "white", "black")
352 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDERSUB
, stc
.STC_MARK_VLINE
, "white", "black")
353 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDER
, stc
.STC_MARK_BOXPLUS
, "white", "black")
354 self
.MarkerDefine(stc
.STC_MARKNUM_FOLDEROPEN
, stc
.STC_MARK_BOXMINUS
, "white", "black")
356 # Global default style
357 if wx
.Platform
== '__WXMSW__':
358 self
.StyleSetSpec(stc
.STC_STYLE_DEFAULT
,
359 'fore:#000000,back:#FFFFFF,face:Courier New,size:9')
361 self
.StyleSetSpec(stc
.STC_STYLE_DEFAULT
,
362 'fore:#000000,back:#FFFFFF,face:Courier,size:12')
364 # Clear styles and revert to default.
367 # Following style specs only indicate differences from default.
368 # The rest remains unchanged.
370 # Line numbers in margin
371 self
.StyleSetSpec(wx
.stc
.STC_STYLE_LINENUMBER
,'fore:#000000,back:#99A9C2')
374 self
.StyleSetSpec(wx
.stc
.STC_STYLE_BRACELIGHT
,'fore:#00009D,back:#FFFF00')
376 self
.StyleSetSpec(wx
.stc
.STC_STYLE_BRACEBAD
,'fore:#00009D,back:#FF0000')
378 self
.StyleSetSpec(wx
.stc
.STC_STYLE_INDENTGUIDE
, "fore:#CDCDCD")
381 self
.StyleSetSpec(wx
.stc
.STC_P_DEFAULT
, 'fore:#000000')
383 self
.StyleSetSpec(wx
.stc
.STC_P_COMMENTLINE
, 'fore:#008000,back:#F0FFF0')
384 self
.StyleSetSpec(wx
.stc
.STC_P_COMMENTBLOCK
, 'fore:#008000,back:#F0FFF0')
386 self
.StyleSetSpec(wx
.stc
.STC_P_NUMBER
, 'fore:#008080')
387 # Strings and characters
388 self
.StyleSetSpec(wx
.stc
.STC_P_STRING
, 'fore:#800080')
389 self
.StyleSetSpec(wx
.stc
.STC_P_CHARACTER
, 'fore:#800080')
391 self
.StyleSetSpec(wx
.stc
.STC_P_WORD
, 'fore:#000080,bold')
393 self
.StyleSetSpec(wx
.stc
.STC_P_TRIPLE
, 'fore:#800080,back:#FFFFEA')
394 self
.StyleSetSpec(wx
.stc
.STC_P_TRIPLEDOUBLE
, 'fore:#800080,back:#FFFFEA')
396 self
.StyleSetSpec(wx
.stc
.STC_P_CLASSNAME
, 'fore:#0000FF,bold')
398 self
.StyleSetSpec(wx
.stc
.STC_P_DEFNAME
, 'fore:#008080,bold')
400 self
.StyleSetSpec(wx
.stc
.STC_P_OPERATOR
, 'fore:#800000,bold')
401 # Identifiers. I leave this as not bold because everything seems
402 # to be an identifier if it doesn't match the above criterae
403 self
.StyleSetSpec(wx
.stc
.STC_P_IDENTIFIER
, 'fore:#000000')
406 self
.SetCaretForeground("BLUE")
407 # Selection background
408 self
.SetSelBackground(1, '#66CCFF')
410 self
.SetSelBackground(True, wx
.SystemSettings_GetColour(wx
.SYS_COLOUR_HIGHLIGHT
))
411 self
.SetSelForeground(True, wx
.SystemSettings_GetColour(wx
.SYS_COLOUR_HIGHLIGHTTEXT
))
415 class DemoCodeViewer(wx
.TextCtrl
):
416 def __init__(self
, parent
, ID
):
417 wx
.TextCtrl
.__init
__(self
, parent
, ID
, style
=
418 wx
.TE_MULTILINE | wx
.TE_READONLY |
419 wx
.HSCROLL | wx
.TE_RICH2 | wx
.TE_NOHIDESEL
)
422 #---------------------------------------------------------------------------
425 """Convert paths to the platform-specific separator"""
426 return apply(os
.path
.join
, tuple(path
.split('/')))
429 #---------------------------------------------------------------------------
431 class wxPythonDemo(wx
.Frame
):
432 overviewText
= "wxPython Overview"
434 def __init__(self
, parent
, id, title
):
435 wx
.Frame
.__init
__(self
, parent
, -1, title
, size
= (800, 600),
436 style
=wx
.DEFAULT_FRAME_STYLE|wx
.NO_FULL_REPAINT_ON_RESIZE
)
439 self
.cwd
= os
.getcwd()
440 self
.curOverview
= ""
443 icon
= images
.getMondrianIcon()
446 if wx
.Platform
!= '__WXMAC__':
447 # setup a taskbar icon, and catch some events from it
448 icon
= wx
.IconFromBitmap(
449 images
.getMondrianImage().Scale(16,16).ConvertToBitmap() )
450 self
.tbicon
= wx
.TaskBarIcon()
451 self
.tbicon
.SetIcon(icon
, "wxPython Demo")
452 self
.tbicon
.Bind(wx
.EVT_TASKBAR_LEFT_DCLICK
, self
.OnTaskBarActivate
)
453 self
.tbicon
.Bind(wx
.EVT_TASKBAR_RIGHT_UP
, self
.OnTaskBarMenu
)
454 self
.tbicon
.Bind(wx
.EVT_MENU
, self
.OnTaskBarActivate
, id=self
.TBMENU_RESTORE
)
455 self
.tbicon
.Bind(wx
.EVT_MENU
, self
.OnTaskBarClose
, id=self
.TBMENU_CLOSE
)
457 wx
.CallAfter(self
.ShowTip
)
460 self
.Bind(wx
.EVT_IDLE
, self
.OnIdle
)
461 self
.Bind(wx
.EVT_CLOSE
, self
.OnCloseWindow
)
462 self
.Bind(wx
.EVT_ICONIZE
, self
.OnIconfiy
)
463 self
.Bind(wx
.EVT_MAXIMIZE
, self
.OnMaximize
)
466 self
.CreateStatusBar(1, wx
.ST_SIZEGRIP
)
468 splitter
= wx
.SplitterWindow(self
, -1, style
=wx
.CLIP_CHILDREN | wx
.SP_LIVE_UPDATE | wx
.SP_3D
)
469 splitter2
= wx
.SplitterWindow(splitter
, -1, style
=wx
.CLIP_CHILDREN | wx
.SP_LIVE_UPDATE | wx
.SP_3D
)
471 # Set up a log on the View Log Notebook page
472 self
.log
= wx
.TextCtrl(splitter2
, -1,
473 style
= wx
.TE_MULTILINE|wx
.TE_READONLY|wx
.HSCROLL
)
475 # Set the wxWindows log target to be this textctrl
476 #wx.Log_SetActiveTarget(wx.LogTextCtrl(self.log))
478 # But instead of the above we want to show how to use our own wx.Log class
479 wx
.Log_SetActiveTarget(MyLog(self
.log
))
481 # for serious debugging
482 #wx.Log_SetActiveTarget(wx.LogStderr())
483 #wx.Log_SetTraceMask(wx.TraceMessages)
487 def EmptyHandler(evt
): pass
488 #splitter.Bind(wx.EVT_ERASE_BACKGROUND, EmptyHandler)
489 #splitter2.Bind(wx.EVT_ERASE_BACKGROUND, EmptyHandler)
491 # Prevent TreeCtrl from displaying all items after destruction when True
495 self
.mainmenu
= wx
.MenuBar()
497 item
= menu
.Append(-1, '&Redirect Output',
498 'Redirect print statements to a window',
500 self
.Bind(wx
.EVT_MENU
, self
.OnToggleRedirect
, item
)
502 item
= menu
.Append(-1, 'E&xit\tAlt-X', 'Get the heck outta here!')
503 self
.Bind(wx
.EVT_MENU
, self
.OnFileExit
, item
)
504 wx
.App_SetMacExitMenuItemId(item
.GetId())
506 self
.mainmenu
.Append(menu
, '&File')
510 for item
in _treeList
:
512 for childItem
in item
[1]:
513 mi
= submenu
.Append(-1, childItem
)
514 self
.Bind(wx
.EVT_MENU
, self
.OnDemoMenu
, mi
)
515 menu
.AppendMenu(wx
.NewId(), item
[0], submenu
)
516 self
.mainmenu
.Append(menu
, '&Demo')
522 findnextID
= wx
.NewId()
524 findItem
= menu
.Append(-1, '&Find\tCtrl-F', 'Find in the Demo Code')
525 findnextItem
= menu
.Append(-1, 'Find &Next\tF3', 'Find Next')
526 menu
.AppendSeparator()
527 helpItem
= menu
.Append(-1, '&About\tCtrl-H', 'wxPython RULES!!!')
528 wx
.App_SetMacAboutMenuItemId(helpItem
.GetId())
529 self
.Bind(wx
.EVT_MENU
, self
.OnHelpAbout
, helpItem
)
530 self
.Bind(wx
.EVT_MENU
, self
.OnHelpFind
, findItem
)
531 self
.Bind(wx
.EVT_MENU
, self
.OnFindNext
, findnextItem
)
532 self
.Bind(wx
.EVT_COMMAND_FIND
, self
.OnFind
)
533 self
.Bind(wx
.EVT_COMMAND_FIND_NEXT
, self
.OnFind
)
534 self
.Bind(wx
.EVT_COMMAND_FIND_CLOSE
, self
.OnFindClose
)
535 self
.mainmenu
.Append(menu
, '&Help')
536 self
.SetMenuBar(self
.mainmenu
)
538 self
.finddata
= wx
.FindReplaceData()
541 # This is another way to set Accelerators, in addition to
542 # using the '\t<key>' syntax in the menu items.
543 aTable
= wx
.AcceleratorTable([(wx
.ACCEL_ALT
, ord('X'), exitID
),
544 (wx
.ACCEL_CTRL
, ord('H'), helpID
),
545 (wx
.ACCEL_CTRL
, ord('F'), findID
),
546 (wx
.ACCEL_NORMAL
, WXK_F3
, findnextID
)
548 self
.SetAcceleratorTable(aTable
)
554 self
.tree
= wx
.TreeCtrl(splitter
, tID
, style
=
555 wx
.TR_DEFAULT_STYLE
#| wx.TR_HAS_VARIABLE_ROW_HEIGHT
558 root
= self
.tree
.AddRoot("wxPython Overview")
560 for item
in _treeList
:
561 child
= self
.tree
.AppendItem(root
, item
[0])
562 if not firstChild
: firstChild
= child
563 for childItem
in item
[1]:
564 theDemo
= self
.tree
.AppendItem(child
, childItem
)
565 self
.treeMap
[childItem
] = theDemo
567 self
.tree
.Expand(root
)
568 self
.tree
.Expand(firstChild
)
569 self
.tree
.Bind(wx
.EVT_TREE_ITEM_EXPANDED
, self
.OnItemExpanded
, id=tID
)
570 self
.tree
.Bind(wx
.EVT_TREE_ITEM_COLLAPSED
, self
.OnItemCollapsed
, id=tID
)
571 self
.tree
.Bind(wx
.EVT_TREE_SEL_CHANGED
, self
.OnSelChanged
, id=tID
)
572 self
.tree
.Bind(wx
.EVT_LEFT_DOWN
, self
.OnTreeLeftDown
)
575 self
.nb
= wx
.Notebook(splitter2
, -1, style
=wx
.CLIP_CHILDREN
)
577 # Set up a wx.html.HtmlWindow on the Overview Notebook page
578 # we put it in a panel first because there seems to be a
579 # refresh bug of some sort (wxGTK) when it is directly in
582 self
.ovr
= wx
.html
.HtmlWindow(self
.nb
, -1, size
=(400, 400))
583 self
.nb
.AddPage(self
.ovr
, self
.overviewText
)
585 else: # hopefully I can remove this hacky code soon, see SF bug #216861
586 panel
= wx
.Panel(self
.nb
, -1, style
=wx
.CLIP_CHILDREN
)
587 self
.ovr
= wx
.html
.HtmlWindow(panel
, -1, size
=(400, 400))
588 self
.nb
.AddPage(panel
, self
.overviewText
)
590 def OnOvrSize(evt
, ovr
=self
.ovr
):
591 ovr
.SetSize(evt
.GetSize())
593 panel
.Bind(wx
.EVT_SIZE
, OnOvrSize
)
594 panel
.Bind(wx
.EVT_ERASE_BACKGROUND
, EmptyHandler
)
597 self
.SetOverview(self
.overviewText
, overview
)
600 # Set up a notebook page for viewing the source code of each sample
601 self
.txt
= DemoCodeViewer(self
.nb
, -1)
602 self
.nb
.AddPage(self
.txt
, "Demo Code")
603 self
.LoadDemoSource('Main.py')
606 # add the windows to the splitter and split it.
607 splitter2
.SplitHorizontally(self
.nb
, self
.log
, -120)
608 splitter
.SplitVertically(self
.tree
, splitter2
, 180)
610 splitter
.SetMinimumPaneSize(20)
611 splitter2
.SetMinimumPaneSize(20)
614 # Make the splitter on the right expand the top window when resized
615 def SplitterOnSize(evt
):
616 splitter
= evt
.GetEventObject()
617 sz
= splitter
.GetSize()
618 splitter
.SetSashPosition(sz
.height
- 120, False)
621 splitter2
.Bind(wx
.EVT_SIZE
, SplitterOnSize
)
624 # select initial items
625 self
.nb
.SetSelection(0)
626 self
.tree
.SelectItem(root
)
628 if len(sys
.argv
) == 2:
630 selectedDemo
= self
.treeMap
[sys
.argv
[1]]
634 self
.tree
.SelectItem(selectedDemo
)
635 self
.tree
.EnsureVisible(selectedDemo
)
638 ## wx.LogMessage('window handle: %s' % self.GetHandle())
641 #---------------------------------------------
642 def WriteText(self
, text
):
643 if text
[-1:] == '\n':
648 def write(self
, txt
):
651 #---------------------------------------------
652 def OnItemExpanded(self
, event
):
653 item
= event
.GetItem()
654 wx
.LogMessage("OnItemExpanded: %s" % self
.tree
.GetItemText(item
))
657 #---------------------------------------------
658 def OnItemCollapsed(self
, event
):
659 item
= event
.GetItem()
660 wx
.LogMessage("OnItemCollapsed: %s" % self
.tree
.GetItemText(item
))
663 #---------------------------------------------
664 def OnTreeLeftDown(self
, event
):
665 pt
= event
.GetPosition();
666 item
, flags
= self
.tree
.HitTest(pt
)
667 if item
== self
.tree
.GetSelection():
668 self
.SetOverview(self
.tree
.GetItemText(item
)+" Overview", self
.curOverview
)
671 #---------------------------------------------
672 def OnSelChanged(self
, event
):
676 item
= event
.GetItem()
677 itemText
= self
.tree
.GetItemText(item
)
678 self
.RunDemo(itemText
)
681 #---------------------------------------------
682 def RunDemo(self
, itemText
):
684 if self
.nb
.GetPageCount() == 3:
685 if self
.nb
.GetSelection() == 2:
686 self
.nb
.SetSelection(0)
687 # inform the window that it's time to quit if it cares
688 if self
.window
is not None:
689 if hasattr(self
.window
, "ShutdownDemo"):
690 self
.window
.ShutdownDemo()
691 wx
.SafeYield() # in case the page has pending events
692 self
.nb
.DeletePage(2)
694 if itemText
== self
.overviewText
:
695 self
.LoadDemoSource('Main.py')
696 self
.SetOverview(self
.overviewText
, overview
)
700 if os
.path
.exists(itemText
+ '.py'):
702 wx
.LogMessage("Running demo %s.py..." % itemText
)
704 self
.LoadDemoSource(itemText
+ '.py')
706 if (sys
.modules
.has_key(itemText
)):
707 reload(sys
.modules
[itemText
])
709 module
= __import__(itemText
, globals())
710 self
.SetOverview(itemText
+ " Overview", module
.overview
)
715 self
.window
= module
.runTest(self
, self
.nb
, self
) ###
716 if self
.window
is not None:
717 self
.nb
.AddPage(self
.window
, 'Demo')
718 self
.nb
.SetSelection(2)
728 #---------------------------------------------
730 def LoadDemoSource(self
, filename
):
733 self
.txt
.SetValue(open(filename
).read())
735 self
.txt
.SetValue("Cannot open %s file." % filename
)
737 self
.txt
.SetInsertionPoint(0)
738 self
.txt
.ShowPosition(0)
740 #---------------------------------------------
741 def SetOverview(self
, name
, text
):
742 self
.curOverview
= text
744 if lead
!= '<html>' and lead
!= '<HTML>':
745 text
= '<br>'.join(text
.split('\n'))
746 self
.ovr
.SetPage(text
)
747 self
.nb
.SetPageText(0, name
)
749 #---------------------------------------------
751 def OnFileExit(self
, *event
):
754 def OnToggleRedirect(self
, event
):
758 print "Print statements and other standard output will now be directed to this window."
761 print "Print statements and other standard output will now be sent to the usual location."
763 def OnHelpAbout(self
, event
):
764 from About
import MyAboutBox
765 about
= MyAboutBox(self
)
769 def OnHelpFind(self
, event
):
770 self
.nb
.SetSelection(1)
771 self
.finddlg
= wx
.FindReplaceDialog(self
, self
.finddata
, "Find",
775 self
.finddlg
.Show(True)
777 def OnFind(self
, event
):
778 self
.nb
.SetSelection(1)
779 end
= self
.txt
.GetLastPosition()
780 textstring
= self
.txt
.GetRange(0, end
).lower()
781 start
= self
.txt
.GetSelection()[1]
782 findstring
= self
.finddata
.GetFindString().lower()
783 loc
= textstring
.find(findstring
, start
)
784 if loc
== -1 and start
!= 0:
785 # string not found, start at beginning
787 loc
= textstring
.find(findstring
, start
)
789 dlg
= wx
.MessageDialog(self
, 'Find String Not Found',
790 'Find String Not Found in Demo File',
791 wx
.OK | wx
.ICON_INFORMATION
)
796 self
.finddlg
.SetFocus()
799 self
.finddlg
.Destroy()
800 self
.txt
.ShowPosition(loc
)
801 self
.txt
.SetSelection(loc
, loc
+ len(findstring
))
805 def OnFindNext(self
, event
):
806 if self
.finddata
.GetFindString():
809 self
.OnHelpFind(event
)
811 def OnFindClose(self
, event
):
812 event
.GetDialog().Destroy()
815 #---------------------------------------------
816 def OnCloseWindow(self
, event
):
823 #---------------------------------------------
824 def OnIdle(self
, event
):
826 self
.otherWin
.Raise()
827 self
.window
= self
.otherWin
831 #---------------------------------------------
834 showTipText
= open(opj("data/showTips")).read()
835 showTip
, index
= eval(showTipText
)
837 showTip
, index
= (1, 0)
839 tp
= wx
.CreateFileTipProvider(opj("data/tips.txt"), index
)
841 showTip
= wx
.ShowTip(self
, tp
)
842 index
= tp
.GetCurrentTip()
843 open(opj("data/showTips"), "w").write(str( (showTip
, index
) ))
846 #---------------------------------------------
847 def OnDemoMenu(self
, event
):
849 selectedDemo
= self
.treeMap
[self
.mainmenu
.GetLabel(event
.GetId())]
853 self
.tree
.SelectItem(selectedDemo
)
854 self
.tree
.EnsureVisible(selectedDemo
)
857 #---------------------------------------------
858 def OnTaskBarActivate(self
, evt
):
859 if self
.IsIconized():
861 if not self
.IsShown():
865 #---------------------------------------------
867 TBMENU_RESTORE
= 1000
870 def OnTaskBarMenu(self
, evt
):
872 menu
.Append(self
.TBMENU_RESTORE
, "Restore wxPython Demo")
873 menu
.Append(self
.TBMENU_CLOSE
, "Close")
874 self
.tbicon
.PopupMenu(menu
)
877 #---------------------------------------------
878 def OnTaskBarClose(self
, evt
):
881 # because of the way wx.TaskBarIcon.PopupMenu is implemented we have to
882 # prod the main idle handler a bit to get the window to actually close
883 wx
.GetApp().ProcessIdle()
886 #---------------------------------------------
887 def OnIconfiy(self
, evt
):
888 wx
.LogMessage("OnIconfiy")
891 #---------------------------------------------
892 def OnMaximize(self
, evt
):
893 wx
.LogMessage("OnMaximize")
899 #---------------------------------------------------------------------------
900 #---------------------------------------------------------------------------
902 class MySplashScreen(wx
.SplashScreen
):
904 bmp
= wx
.Image(opj("bitmaps/splash.gif")).ConvertToBitmap()
905 wx
.SplashScreen
.__init
__(self
, bmp
,
906 wx
.SPLASH_CENTRE_ON_SCREEN | wx
.SPLASH_TIMEOUT
,
908 self
.Bind(wx
.EVT_CLOSE
, self
.OnClose
)
910 def OnClose(self
, evt
):
912 frame
= wxPythonDemo(None, -1, "wxPython: (A Demonstration)")
914 evt
.Skip() # Make sure the default handler runs too...
920 Create and show the splash screen. It will then create and show
921 the main frame when it is time to do so.
924 wx
.InitAllImageHandlers()
926 # Normally when using a SplashScreen you would create it, show
927 # it and then continue on with the applicaiton's
928 # initialization, finally creating and showing the main
929 # application window(s). In this case we have nothing else to
930 # do so we'll delay showing the main frame until later (see
931 # OnClose above) so the users can see the SplashScrren effect.
932 splash
= MySplashScreen()
939 #---------------------------------------------------------------------------
943 demoPath
= os
.path
.dirname(__file__
)
947 app
= MyApp(0) ##wx.Platform == "__WXMAC__")
951 #---------------------------------------------------------------------------
955 overview
= """<html><body>
958 <p> wxPython is a <b>GUI toolkit</b> for the <a
959 href="http://www.python.org/">Python</a> programming language. It
960 allows Python programmers to create programs with a robust, highly
961 functional graphical user interface, simply and easily. It is
962 implemented as a Python extension module (native code) that wraps the
963 popular <a href="http://wxwindows.org/front.htm">wxWindows</a> cross
964 platform GUI library, which is written in C++.
966 <p> Like Python and wxWindows, wxPython is <b>Open Source</b> which
967 means that it is free for anyone to use and the source code is
968 available for anyone to look at and modify. Or anyone can contribute
969 fixes or enhancements to the project.
971 <p> wxPython is a <b>cross-platform</b> toolkit. This means that the
972 same program will run on multiple platforms without modification.
973 Currently supported platforms are 32-bit Microsoft Windows, most Unix
974 or unix-like systems, and Macintosh OS X. Since the language is
975 Python, wxPython programs are <b>simple, easy</b> to write and easy to
978 <p> <b>This demo</b> is not only a collection of test cases for
979 wxPython, but is also designed to help you learn about and how to use
980 wxPython. Each sample is listed in the tree control on the left.
981 When a sample is selected in the tree then a module is loaded and run
982 (usually in a tab of this notebook,) and the source code of the module
983 is loaded in another tab for you to browse and learn from.
988 #----------------------------------------------------------------------------
989 #----------------------------------------------------------------------------
991 if __name__
== '__main__':
994 #----------------------------------------------------------------------------