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