]> git.saurik.com Git - wxWidgets.git/blob - wxPython/demo/ComboBox.py
SWIG 1.3.29
[wxWidgets.git] / wxPython / demo / ComboBox.py
1
2 import wx
3
4 #---------------------------------------------------------------------------
5
6 class TestComboBox(wx.Panel):
7 def OnSetFocus(self, evt):
8 print "OnSetFocus"
9 evt.Skip()
10
11 def OnKillFocus(self, evt):
12 print "OnKillFocus"
13 evt.Skip()
14
15 def __init__(self, parent, log):
16 self.log = log
17 wx.Panel.__init__(self, parent, -1)
18
19 sampleList = ['zero', 'one', 'two', 'three', 'four', 'five',
20 #'this is a long item that needs a scrollbar...',
21 'six', 'seven', 'eight']
22
23 wx.StaticText(self, -1, "This example uses the wx.ComboBox control.", (8, 10))
24 wx.StaticText(self, -1, "Select one:", (15, 50), (75, 18))
25
26 # This combobox is created with a preset list of values.
27 cb = wx.ComboBox(
28 self, 500, "default value", (90, 50),
29 (95, -1), sampleList, wx.CB_DROPDOWN #|wxTE_PROCESS_ENTER
30 )
31
32 self.Bind(wx.EVT_COMBOBOX, self.EvtComboBox, cb)
33 self.Bind(wx.EVT_TEXT, self.EvtText, cb)
34 self.Bind(wx.EVT_TEXT_ENTER, self.EvtTextEnter, cb)
35 cb.Bind(wx.EVT_SET_FOCUS, self.OnSetFocus)
36 cb.Bind(wx.EVT_KILL_FOCUS, self.OnKillFocus)
37
38 # Once the combobox is set up, we can append some more data to it.
39 cb.Append("foo", "This is some client data for this item")
40
41 # This combobox is created with no values initially.
42 cb = wx.ComboBox(
43 self, 501, "default value", (90, 80), (95, -1), [], wx.CB_DROPDOWN)
44
45 # Here we dynamically add our values to the second combobox.
46 for item in sampleList:
47 cb.Append(item, item.upper())
48
49 self.Bind(wx.EVT_COMBOBOX, self.EvtComboBox, cb)
50
51 # When the user selects something, we go here.
52 def EvtComboBox(self, evt):
53 cb = evt.GetEventObject()
54 data = cb.GetClientData(evt.GetSelection())
55 self.log.WriteText('EvtComboBox: %s\nClientData: %s\n' % (evt.GetString(), data))
56
57 if evt.GetString() == 'one':
58 self.log.WriteText("You follow directions well!\n\n")
59
60 # Capture events every time a user hits a key in the text entry field.
61 def EvtText(self, evt):
62 self.log.WriteText('EvtText: %s\n' % evt.GetString())
63
64 # Capture events when the user types something into the control then
65 # hits ENTER.
66 def EvtTextEnter(self, evt):
67 self.log.WriteText('EvtTextEnter: %s' % evt.GetString())
68
69 #---------------------------------------------------------------------------
70
71 def runTest(frame, nb, log):
72 win = TestComboBox(nb, log)
73 return win
74
75 #---------------------------------------------------------------------------
76
77
78 overview = """\
79 A ComboBox is like a combination of an edit control and a listbox. It can be
80 displayed as static list with editable or read-only text field; or a drop-down
81 list with text field; or a drop-down list without a text field.
82
83 This example shows both a preset ComboBox and one that is dynamically created
84 (that is, it is initially empty but then we 'grow' it out of program-supplied
85 data). The former is common for read-only controls.
86
87 This example also shows the two form factors for the ComboBox. The first is more
88 common, and resembles a Choice control. The latter, although less common, shows
89 how all the values in the ComboBox can be visible, yet the functionality is the
90 same for both.
91
92 Finally, this demo shows how event handling can differ. The first ComboBox is set
93 up to handle EVT_TEXT_ENTER events, in which text is typed in and then ENTER is
94 hit by the user. This allows the user to enter a line of text which can then be
95 processed by the program. EVT_TEXT can also be processed, but in that case the
96 event is generated every time that the user hits a key in the ComboBox entry field.
97
98 """
99
100 #---------------------------------------------------------------------------
101
102 if __name__ == '__main__':
103 import sys,os
104 import run
105 run.main(['', os.path.basename(sys.argv[0])] + sys.argv[1:])
106