]> git.saurik.com Git - wxWidgets.git/blob - wxPython/demo/wxMultiSash.py
Aquire the GIL before raising the NotImplementedError exception
[wxWidgets.git] / wxPython / demo / wxMultiSash.py
1 # 11/20/2003 - Jeff Grimmett (grimmtooth@softhome.net)
2 #
3 # o Updated for wx namespace
4 #
5 # 11/30/2003 - Jeff Grimmett (grimmtooth@softhome.net)
6 #
7 # o wx renamer needs to be applied to multisash lib.
8 # o There appears to be a problem with the image that
9 # the library is trying to use for the alternate cursor
10 #
11 # 12/09/2003 - Jeff Grimmett (grimmtooth@softhome.net)
12 #
13 # o renamer issue shelved.
14 #
15
16 import wx
17 import wx.lib.multisash as sash
18 import wx.stc as stc
19
20 #---------------------------------------------------------------------------
21
22 sampleText="""\
23 You can drag the little tab on the vertical sash left to create another view,
24 or you can drag the tab on the horizontal sash to the top to create another
25 horizontal view.
26
27 The red blocks on the sashes will destroy the view (bottom,left) this block
28 belongs to.
29
30 A yellow rectangle also highlights the current selected view.
31
32 By calling GetSaveData on the multiSash control the control will return its
33 contents and the positions of each sash as a dictionary.
34 Calling SetSaveData with such a dictionary will restore the control to the
35 state it was in when it was saved.
36
37 If the class, that is used as a view, has GetSaveData/SetSaveData implemented,
38 these will also be called to save/restore their state. Any object can be
39 returned by GetSaveData, as it is just another object in the dictionary.
40 """
41
42 #---------------------------------------------------------------------------
43
44 class TestWindow(stc.StyledTextCtrl):
45
46 # shared document reference
47 doc = None
48
49 def __init__(self, parent):
50 stc.StyledTextCtrl.__init__(self, parent, -1, style=wx.NO_BORDER)
51 self.SetMarginWidth(1,0)
52
53 if wx.Platform == '__WXMSW__':
54 fSize = 10
55 else:
56 fSize = 12
57
58 self.StyleSetFont(
59 stc.STC_STYLE_DEFAULT,
60 wx.Font(fSize, wx.MODERN, wx.NORMAL, wx.NORMAL)
61 )
62
63 if self.doc:
64 self.SetDocPointer(self.doc)
65 else:
66 self.SetText(sampleText)
67 TestWindow.doc = self.GetDocPointer()
68
69
70 def SutdownDemo(self):
71 # Reset doc reference in case this demo is run again
72 TestWindow.doc = None
73
74
75 #---------------------------------------------------------------------------
76
77
78 def runTest(frame, nb, log):
79 multi = sash.wxMultiSash(nb, -1, pos = (0,0), size = (640,480))
80
81 # Use this method to set the default class that will be created when
82 # a new sash is created. The class's constructor needs 1 parameter
83 # which is the parent of the window
84 multi.SetDefaultChildClass(TestWindow)
85
86 return multi
87
88 #----------------------------------------------------------------------
89
90
91
92 overview = """<html><body>
93 <h2><center>wxMultiSash</center></h2>
94
95 wxMultiSash allows the user to split a window any number of times
96 either horizontally or vertically, and to close the split off windows
97 when desired.
98
99 </body></html>
100 """
101
102
103
104 if __name__ == '__main__':
105 import sys,os
106 import run
107 run.main(['', os.path.basename(sys.argv[0])])
108