]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/wxListBox.py
Morec ompilation fixes.
[wxWidgets.git] / wxPython / demo / wxListBox.py
index ce659bd79ca8cbf0e094cffde2767c26b871bbc1..074f2de5ae48c0ea467c3f5e672e998c7a229e7a 100644 (file)
@@ -1,8 +1,6 @@
 
 from wxPython.wx import *
 
 
 from wxPython.wx import *
 
-import string
-
 #---------------------------------------------------------------------------
 
 class wxFindPrefixListBox(wxListBox):
 #---------------------------------------------------------------------------
 
 class wxFindPrefixListBox(wxListBox):
@@ -10,18 +8,22 @@ class wxFindPrefixListBox(wxListBox):
                  choices=[], style=0, validator=wxDefaultValidator):
         wxListBox.__init__(self, parent, id, pos, size, choices, style, validator)
         self.typedText = ''
                  choices=[], style=0, validator=wxDefaultValidator):
         wxListBox.__init__(self, parent, id, pos, size, choices, style, validator)
         self.typedText = ''
-        EVT_KEY_UP(self, self.OnKey)
+        self.log = parent.log
+        EVT_KEY_DOWN(self, self.OnKey)
 
 
     def FindPrefix(self, prefix):
 
 
     def FindPrefix(self, prefix):
+        self.log.WriteText('Looking for prefix: %s\n' % prefix)
         if prefix:
         if prefix:
-            prefix = string.lower(prefix)
+            prefix = prefix.lower()
             length = len(prefix)
             for x in range(self.Number()):
                 text = self.GetString(x)
             length = len(prefix)
             for x in range(self.Number()):
                 text = self.GetString(x)
-                text = string.lower(text)
+                text = text.lower()
                 if text[:length] == prefix:
                 if text[:length] == prefix:
+                    self.log.WriteText('Prefix %s is found.\n' % prefix)
                     return x
                     return x
+        self.log.WriteText('Prefix %s is not found.\n' % prefix)
         return -1
 
 
         return -1
 
 
@@ -43,8 +45,12 @@ class wxFindPrefixListBox(wxListBox):
                     self.SetSelection(item)
 
         else:
                     self.SetSelection(item)
 
         else:
+            self.typedText = ''
             evt.Skip()
 
             evt.Skip()
 
+    def OnKeyDown(self, evt):
+        pass
+
 
 #---------------------------------------------------------------------------
 
 
 #---------------------------------------------------------------------------
 
@@ -66,14 +72,16 @@ class TestListBox(wxPanel):
         EVT_LISTBOX(self, 60, self.EvtListBox)
         EVT_LISTBOX_DCLICK(self, 60, self.EvtListBoxDClick)
         EVT_RIGHT_UP(self.lb1, self.EvtRightButton)
         EVT_LISTBOX(self, 60, self.EvtListBox)
         EVT_LISTBOX_DCLICK(self, 60, self.EvtListBoxDClick)
         EVT_RIGHT_UP(self.lb1, self.EvtRightButton)
-        self.lb1.SetSelection(0)
+        self.lb1.SetSelection(3)
+        self.lb1.Append("with data", "This one has data");
+        self.lb1.SetClientData(2, "This one has data");
 
 
         wxStaticText(self, -1, "Select many:", wxPoint(200, 50), wxSize(65, 18))
         self.lb2 = wxListBox(self, 70, wxPoint(280, 50), wxSize(80, 120),
                        sampleList, wxLB_EXTENDED)
         EVT_LISTBOX(self, 70, self.EvtMultiListBox)
 
 
         wxStaticText(self, -1, "Select many:", wxPoint(200, 50), wxSize(65, 18))
         self.lb2 = wxListBox(self, 70, wxPoint(280, 50), wxSize(80, 120),
                        sampleList, wxLB_EXTENDED)
         EVT_LISTBOX(self, 70, self.EvtMultiListBox)
-        EVT_LISTBOX_DCLICK(self, 70, self.EvtListBoxDClick)
+        EVT_RIGHT_UP(self.lb2, self.EvtRightButton)
         self.lb2.SetSelection(0)
 
 
         self.lb2.SetSelection(0)
 
 
@@ -88,7 +96,14 @@ class TestListBox(wxPanel):
 
 
     def EvtListBox(self, event):
 
 
     def EvtListBox(self, event):
-        self.log.WriteText('EvtListBox: %s\n' % event.GetString())
+        self.log.WriteText('EvtListBox: %s, %s, %s\n' %
+                           (event.GetString(), event.IsSelection(), event.GetSelection()))
+
+        lb = event.GetEventObject()
+        data = lb.GetClientData(lb.GetSelection())
+        if data is not None:
+            self.log.WriteText('\tdata: %s\n' % data)
+
 
     def EvtListBoxDClick(self, event):
         self.log.WriteText('EvtListBoxDClick: %s\n' % self.lb1.GetSelection())
 
     def EvtListBoxDClick(self, event):
         self.log.WriteText('EvtListBoxDClick: %s\n' % self.lb1.GetSelection())
@@ -99,6 +114,12 @@ class TestListBox(wxPanel):
 
     def EvtRightButton(self, event):
         self.log.WriteText('EvtRightButton: %s\n' % event.GetPosition())
 
     def EvtRightButton(self, event):
         self.log.WriteText('EvtRightButton: %s\n' % event.GetPosition())
+        if event.GetEventObject().GetId() == 70:
+            selections = list(self.lb2.GetSelections())
+            selections.reverse()
+            for index in selections:
+                self.lb2.Delete(index)
+
 
 #---------------------------------------------------------------------------
 
 
 #---------------------------------------------------------------------------
 
@@ -114,45 +135,19 @@ def runTest(frame, nb, log):
 
 
 
 
 
 
+overview = """<html><body>
+A listbox is used to select one or more of a list of
+strings. The strings are displayed in a scrolling box, with the
+selected string(s) marked in reverse video. A listbox can be single
+selection (if an item is selected, the previous selection is removed)
+or multiple selection (clicking an item toggles the item on or off
+independently of other selections).
+</body></html>
+"""
 
 
 
 
+if __name__ == '__main__':
+    import sys,os
+    import run
+    run.main(['', os.path.basename(sys.argv[0])])
 
 
-
-
-
-
-overview = """\
-A listbox is used to select one or more of a list of strings. The strings are displayed in a scrolling box, with the selected string(s) marked in reverse video. A listbox can be single selection (if an item is selected, the previous selection is removed) or multiple selection (clicking an item toggles the item on or off independently of other selections).
-
-List box elements are numbered from zero.
-
-wxListBox()
----------------------
-
-Default constructor.
-
-wxListBox(wxWindow* parent, wxWindowID id, const wxPoint& pos = wxDefaultPosition, const wxSize& size = wxDefaultSize, int n, const wxString choices[] = NULL, long style = 0, const wxValidator& validator = wxDefaultValidator, const wxString& name = "listBox")
-
-Constructor, creating and showing a list box.
-
-Parameters
--------------------
-
-parent = Parent window. Must not be NULL.
-
-id = Window identifier. A value of -1 indicates a default value.
-
-pos = Window position.
-
-size = Window size. If the default size (-1, -1) is specified then the window is sized appropriately.
-
-n = Number of strings with which to initialise the control.
-
-choices = An array of strings with which to initialise the control.
-
-style = Window style. See wxListBox.
-
-validator = Window validator.
-
-name = Window name.
-"""