X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/00887b391beda723d1a87bb094012c2061b65bda..72858fcf67bf670ea18fe48a6b039d61afa87131:/wxPython/demo/wxListCtrl.py diff --git a/wxPython/demo/wxListCtrl.py b/wxPython/demo/wxListCtrl.py index 41645a29c3..32b3a3f461 100644 --- a/wxPython/demo/wxListCtrl.py +++ b/wxPython/demo/wxListCtrl.py @@ -11,7 +11,7 @@ #---------------------------------------------------------------------------- from wxPython.wx import * -from wxPython.lib.mixins.listctrl import wxColumnSorterMixin +from wxPython.lib.mixins.listctrl import wxColumnSorterMixin, wxListCtrlAutoWidthMixin #--------------------------------------------------------------------------- @@ -74,6 +74,15 @@ musicdata = { import images + +class TestListCtrl(wxListCtrl, wxListCtrlAutoWidthMixin): + def __init__(self, parent, ID, pos=wxDefaultPosition, + size=wxDefaultSize, style=0): + wxListCtrl.__init__(self, parent, ID, pos, size, style) + wxListCtrlAutoWidthMixin.__init__(self) + + + class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): def __init__(self, parent, log): wxPanel.__init__(self, parent, -1, style=wxWANTS_CHARS) @@ -83,23 +92,51 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): self.il = wxImageList(16, 16) - idx1 = self.il.Add(images.getSmilesBitmap()) + self.idx1 = self.il.Add(images.getSmilesBitmap()) self.sm_up = self.il.Add(images.getSmallUpArrowBitmap()) self.sm_dn = self.il.Add(images.getSmallDnArrowBitmap()) - #idx1 = self.il.AddIcon(wxIconFromXPMData(images.getSmilesData())) - #self.sm_up = self.il.AddIcon(wxIconFromXPMData(images.getSmallUpArrowData())) - #self.sm_dn = self.il.AddIcon(wxIconFromXPMData(images.getSmallDnArrowData())) - - self.list = wxListCtrl(self, tID, - style=wxLC_REPORT|wxSUNKEN_BORDER)#|wxLC_VRULES|wxLC_HRULES) + self.list = TestListCtrl(self, tID, + style=wxLC_REPORT | wxSUNKEN_BORDER + | wxLC_EDIT_LABELS + #| wxLC_NO_HEADER + #| wxLC_VRULES | wxLC_HRULES + ) self.list.SetImageList(self.il, wxIMAGE_LIST_SMALL) - # Why doesn't this show up on MSW??? - self.list.SetToolTip(wxToolTip("This is a ToolTip!")) + self.PopulateList() + # Now that the list exists we can init the other base class, + # see wxPython/lib/mixins/listctrl.py + self.itemDataMap = musicdata + wxColumnSorterMixin.__init__(self, 3) + #self.SortListItems(0, True) + + EVT_SIZE(self, self.OnSize) + EVT_LIST_ITEM_SELECTED(self, tID, self.OnItemSelected) + EVT_LIST_ITEM_DESELECTED(self, tID, self.OnItemDeselected) + EVT_LIST_ITEM_ACTIVATED(self, tID, self.OnItemActivated) + EVT_LIST_DELETE_ITEM(self, tID, self.OnItemDelete) + EVT_LIST_COL_CLICK(self, tID, self.OnColClick) + EVT_LIST_COL_RIGHT_CLICK(self, tID, self.OnColRightClick) + EVT_LIST_COL_BEGIN_DRAG(self, tID, self.OnColBeginDrag) + EVT_LIST_COL_DRAGGING(self, tID, self.OnColDragging) + EVT_LIST_COL_END_DRAG(self, tID, self.OnColEndDrag) + EVT_LIST_BEGIN_LABEL_EDIT(self, tID, self.OnBeginEdit) + + EVT_LEFT_DCLICK(self.list, self.OnDoubleClick) + EVT_RIGHT_DOWN(self.list, self.OnRightDown) + + # for wxMSW + EVT_COMMAND_RIGHT_CLICK(self.list, tID, self.OnRightClick) + + # for wxGTK + EVT_RIGHT_UP(self.list, self.OnRightClick) + + + def PopulateList(self): if 0: - # for normal simple columns, you can add them like this: + # for normal, simple columns, you can add them like this: self.list.InsertColumn(0, "Artist") self.list.InsertColumn(1, "Title", wxLIST_FORMAT_RIGHT) self.list.InsertColumn(2, "Genre") @@ -120,22 +157,14 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): info.m_text = "Genre" self.list.InsertColumnInfo(2, info) - - items = musicdata.items() for x in range(len(items)): key, data = items[x] - self.list.InsertImageStringItem(x, data[0], idx1) + self.list.InsertImageStringItem(x, data[0], self.idx1) self.list.SetStringItem(x, 1, data[1]) self.list.SetStringItem(x, 2, data[2]) self.list.SetItemData(x, key) - # Now that the list exists we can init the other base class, - # see wxPython/lib/mixins/listctrl.py - self.itemDataMap = musicdata - wxColumnSorterMixin.__init__(self, 3) - #self.SortListItems(0, true) - self.list.SetColumnWidth(0, wxLIST_AUTOSIZE) self.list.SetColumnWidth(1, wxLIST_AUTOSIZE) self.list.SetColumnWidth(2, 100) @@ -152,24 +181,6 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): self.list.SetItem(item) self.currentItem = 0 - EVT_SIZE(self, self.OnSize) - EVT_LIST_ITEM_SELECTED(self, tID, self.OnItemSelected) - EVT_LIST_ITEM_ACTIVATED(self, tID, self.OnItemActivated) - EVT_LIST_DELETE_ITEM(self, tID, self.OnItemDelete) - EVT_LIST_COL_CLICK(self, tID, self.OnColClick) - EVT_LIST_COL_RIGHT_CLICK(self, tID, self.OnColRightClick) - EVT_LIST_COL_BEGIN_DRAG(self, tID, self.OnColBeginDrag) - EVT_LIST_COL_DRAGGING(self, tID, self.OnColDragging) - EVT_LIST_COL_END_DRAG(self, tID, self.OnColEndDrag) - - EVT_LEFT_DCLICK(self.list, self.OnDoubleClick) - EVT_RIGHT_DOWN(self.list, self.OnRightDown) - - # for wxMSW - EVT_COMMAND_RIGHT_CLICK(self.list, tID, self.OnRightClick) - - # for wxGTK - EVT_RIGHT_UP(self.list, self.OnRightClick) # Used by the wxColumnSorterMixin, see wxPython/lib/mixins/listctrl.py @@ -181,12 +192,13 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): return (self.sm_dn, self.sm_up) - def OnRightDown(self, event): self.x = event.GetX() self.y = event.GetY() self.log.WriteText("x, y = %s\n" % str((self.x, self.y))) - print event.GetEventObject() + item, flags = self.list.HitTest((self.x, self.y)) + if flags & wxLIST_HITTEST_ONITEM: + self.list.Select(item) event.Skip() @@ -196,6 +208,7 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): def OnItemSelected(self, event): + ##print event.GetItem().GetTextColour() self.currentItem = event.m_itemIndex self.log.WriteText("OnItemSelected: %s, %s, %s, %s\n" % (self.currentItem, @@ -207,10 +220,26 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): #event.Veto() # doesn't work # this does self.list.SetItemState(10, 0, wxLIST_STATE_SELECTED) + event.Skip() + + + def OnItemDeselected(self, evt): + item = evt.GetItem() + self.log.WriteText("OnItemDeselected: %d" % evt.m_itemIndex) + + # Show how to reselect something we don't want deselected + if evt.m_itemIndex == 11: + wxCallAfter(self.list.SetItemState, 11, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED) + def OnItemActivated(self, event): self.currentItem = event.m_itemIndex - self.log.WriteText("OnItemActivated: %s\n" % self.list.GetItemText(self.currentItem)) + self.log.WriteText("OnItemActivated: %s\nTopItem: %s" % + (self.list.GetItemText(self.currentItem), self.list.GetTopItem())) + + def OnBeginEdit(self, event): + self.log.WriteText("OnBeginEdit") + event.Allow() def OnItemDelete(self, event): self.log.WriteText("OnItemDelete\n") @@ -219,10 +248,17 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): self.log.WriteText("OnColClick: %d\n" % event.GetColumn()) def OnColRightClick(self, event): - self.log.WriteText("OnColRightClick: %d\n" % event.GetColumn()) + item = self.list.GetColumn(event.GetColumn()) + self.log.WriteText("OnColRightClick: %d %s\n" % + (event.GetColumn(), (item.GetText(), item.GetAlign(), + item.GetWidth(), item.GetImage()))) def OnColBeginDrag(self, event): self.log.WriteText("OnColBeginDrag\n") + ## Show how to not allow a column to be resized + #if event.GetColumn() == 0: + # event.Veto() + def OnColDragging(self, event): self.log.WriteText("OnColDragging\n") @@ -236,37 +272,55 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): def OnRightClick(self, event): self.log.WriteText("OnRightClick %s\n" % self.list.GetItemText(self.currentItem)) + + # only do this part the first time so the events are only bound once + if not hasattr(self, "popupID1"): + self.popupID1 = wxNewId() + self.popupID2 = wxNewId() + self.popupID3 = wxNewId() + self.popupID4 = wxNewId() + self.popupID5 = wxNewId() + self.popupID6 = wxNewId() + EVT_MENU(self, self.popupID1, self.OnPopupOne) + EVT_MENU(self, self.popupID2, self.OnPopupTwo) + EVT_MENU(self, self.popupID3, self.OnPopupThree) + EVT_MENU(self, self.popupID4, self.OnPopupFour) + EVT_MENU(self, self.popupID5, self.OnPopupFive) + EVT_MENU(self, self.popupID6, self.OnPopupSix) + + # make a menu menu = wxMenu() - tPopupID1 = 0 - tPopupID2 = 1 - tPopupID3 = 2 - tPopupID4 = 3 - tPopupID5 = 5 - #menu.Append(tPopupID1, "One") - item = wxMenuItem(menu, tPopupID1,"One") - item.SetBitmap(images.getSmilesBitmap()) - menu.AppendItem(item) - menu.Append(tPopupID2, "Two") - menu.Append(tPopupID3, "Three") - menu.Append(tPopupID4, "DeleteAllItems") - menu.Append(tPopupID5, "GetItem") - EVT_MENU(self, tPopupID1, self.OnPopupOne) - EVT_MENU(self, tPopupID2, self.OnPopupTwo) - EVT_MENU(self, tPopupID3, self.OnPopupThree) - EVT_MENU(self, tPopupID4, self.OnPopupFour) - EVT_MENU(self, tPopupID5, self.OnPopupFive) + # add some items + menu.Append(self.popupID1, "FindItem tests") + menu.Append(self.popupID2, "Iterate Selected") + menu.Append(self.popupID3, "ClearAll and repopulate") + menu.Append(self.popupID4, "DeleteAllItems") + menu.Append(self.popupID5, "GetItem") + menu.Append(self.popupID6, "Edit") + + # Popup the menu. If an item is selected then its handler + # will be called before PopupMenu returns. self.PopupMenu(menu, wxPoint(self.x, self.y)) menu.Destroy() - event.Skip() + def OnPopupOne(self, event): self.log.WriteText("Popup one\n") + print "FindItem:", self.list.FindItem(-1, "Roxette") + print "FindItemData:", self.list.FindItemData(-1, 11) def OnPopupTwo(self, event): - self.log.WriteText("Popup two\n") + self.log.WriteText("Selected items:\n") + index = self.list.GetFirstSelected() + while index != -1: + self.log.WriteText(" %s: %s\n" % (self.list.GetItemText(index), self.getColumnText(index, 1))) + index = self.list.GetNextSelected(index) + def OnPopupThree(self, event): self.log.WriteText("Popup three\n") + self.list.ClearAll() + wxCallAfter(self.PopulateList) def OnPopupFour(self, event): self.list.DeleteAllItems() @@ -275,6 +329,10 @@ class TestListCtrlPanel(wxPanel, wxColumnSorterMixin): item = self.list.GetItem(self.currentItem) print item.m_text, item.m_itemId, self.list.GetItemData(self.currentItem) + def OnPopupSix(self, event): + self.list.EditLabel(self.currentItem) + + def OnSize(self, event): w,h = self.GetClientSizeTuple() self.list.SetDimensions(0, 0, w, h) @@ -295,19 +353,17 @@ def runTest(frame, nb, log): +overview = """\ +A list control presents lists in a number of formats: list view, report view, icon view and small icon view. Elements are numbered from zero. +""" +if __name__ == '__main__': + import sys,os + import run + run.main(['', os.path.basename(sys.argv[0])]) - - - - - -overview = """\ -A list control presents lists in a number of formats: list view, report view, icon view and small icon view. Elements are numbered from zero. - -"""