X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/493f1553fdfd276ed9944c5f1c070ee34be13b52..249a57f4438ef017764e7b317fce1c9847ed45dc:/wxPython/demo/wxListCtrl.py?ds=sidebyside diff --git a/wxPython/demo/wxListCtrl.py b/wxPython/demo/wxListCtrl.py index fb193c9638..2dcd901785 100644 --- a/wxPython/demo/wxListCtrl.py +++ b/wxPython/demo/wxListCtrl.py @@ -1,4 +1,3 @@ -#!/bin/env python #---------------------------------------------------------------------------- # Name: ListCtrl.py # Purpose: Testing lots of stuff, controls, window types, etc. @@ -12,6 +11,7 @@ #---------------------------------------------------------------------------- from wxPython.wx import * +from wxPython.lib.mixins.listctrl import wxColumnSorterMixin, wxListCtrlAutoWidthMixin #--------------------------------------------------------------------------- @@ -55,11 +55,35 @@ musicdata = { 37: ("Spyro Gyra", "Song for Lorraine", "Jazz"), 38: ("Yes", "Owner Of A Lonely Heart", "Rock"), 39: ("Yes", "Rhythm Of Love", "Rock"), +40: ("Cusco", "Dream Catcher", "New Age"), +41: ("Cusco", "Geronimos Laughter", "New Age"), +42: ("Cusco", "Ghost Dance", "New Age"), +43: ("Blue Man Group", "Drumbone", "New Age"), +44: ("Blue Man Group", "Endless Column", "New Age"), +45: ("Blue Man Group", "Klein Mandelbrot", "New Age"), +46: ("Kenny G", "Silhouette", "Jazz"), +47: ("Sade", "Smooth Operator", "Jazz"), +48: ("David Arkenstone", "Papillon (On The Wings Of The Butterfly)", "New Age"), +49: ("David Arkenstone", "Stepping Stars", "New Age"), +50: ("David Arkenstone", "Carnation Lily Lily Rose", "New Age"), +51: ("David Lanz", "Behind The Waterfall", "New Age"), +52: ("David Lanz", "Cristofori's Dream", "New Age"), +53: ("David Lanz", "Heartsounds", "New Age"), +54: ("David Lanz", "Leaves on the Seine", "New Age"), } import images -class TestListCtrlPanel(wxPanel): + +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) @@ -67,19 +91,46 @@ class TestListCtrlPanel(wxPanel): tID = wxNewId() self.il = wxImageList(16, 16) - bmp = images.getSmilesBitmap() - idx1 = self.il.AddWithColourMask(bmp, wxWHITE) - self.list = wxListCtrl(self, tID, - style=wxLC_REPORT|wxSUNKEN_BORDER) + 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 = TestListCtrl(self, tID, + style=wxLC_REPORT|wxSUNKEN_BORDER)#|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.list.SetToolTip(wxToolTip("This is a ToolTip!")) + + if 0: + # 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") + else: + # but since we want images on the column header we have to do it the hard way: + info = wxListItem() + info.m_mask = wxLIST_MASK_TEXT | wxLIST_MASK_IMAGE | wxLIST_MASK_FORMAT + info.m_image = -1 + info.m_format = 0 + info.m_text = "Artist" + self.list.InsertColumnInfo(0, info) + + info.m_format = wxLIST_FORMAT_RIGHT + info.m_text = "Title" + self.list.InsertColumnInfo(1, info) + + info.m_format = 0 + info.m_text = "Genre" + self.list.InsertColumnInfo(2, info) + + - self.list.InsertColumn(0, "Artist") - self.list.InsertColumn(1, "Title", wxLIST_FORMAT_RIGHT) - self.list.InsertColumn(2, "Genre") items = musicdata.items() for x in range(len(items)): key, data = items[x] @@ -88,19 +139,26 @@ class TestListCtrlPanel(wxPanel): 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, wxLIST_AUTOSIZE) + self.list.SetColumnWidth(2, 100) + # show how to select an item self.list.SetItemState(5, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED) - #self.list.SetItemState(25, wxLIST_STATE_SELECTED, wxLIST_STATE_SELECTED) - #self.list.EnsureVisible(25) - - # show how to change the colour of an item + # show how to change the colour of a couple items item = self.list.GetItem(1) item.SetTextColour(wxBLUE) self.list.SetItem(item) + item = self.list.GetItem(4) + item.SetTextColour(wxRED) + self.list.SetItem(item) self.currentItem = 0 EVT_SIZE(self, self.OnSize) @@ -108,6 +166,11 @@ class TestListCtrlPanel(wxPanel): 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) @@ -118,10 +181,21 @@ class TestListCtrlPanel(wxPanel): EVT_RIGHT_UP(self.list, self.OnRightClick) + # Used by the wxColumnSorterMixin, see wxPython/lib/mixins/listctrl.py + def GetListCtrl(self): + return self.list + + # Used by the wxColumnSorterMixin, see wxPython/lib/mixins/listctrl.py + def GetSortImages(self): + 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() event.Skip() @@ -143,7 +217,6 @@ class TestListCtrlPanel(wxPanel): # this does self.list.SetItemState(10, 0, wxLIST_STATE_SELECTED) - def OnItemActivated(self, event): self.currentItem = event.m_itemIndex self.log.WriteText("OnItemActivated: %s\n" % self.list.GetItemText(self.currentItem)) @@ -152,17 +225,26 @@ class TestListCtrlPanel(wxPanel): self.log.WriteText("OnItemDelete\n") def OnColClick(self, event): - self.log.WriteText("OnColClick: %d\n" % event.m_col) - self.col = event.m_col - self.list.SortItems(self.ColumnSorter) + self.log.WriteText("OnColClick: %d\n" % event.GetColumn()) + + def OnColRightClick(self, event): + 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 ColumnSorter(self, key1, key2): - item1 = musicdata[key1][self.col] - item2 = musicdata[key2][self.col] - if item1 == item2: return 0 - elif item1 < item2: return -1 - else: return 1 + def OnColDragging(self, event): + self.log.WriteText("OnColDragging\n") + + def OnColEndDrag(self, event): + self.log.WriteText("OnColEndDrag\n") def OnDoubleClick(self, event): self.log.WriteText("OnDoubleClick item %s\n" % self.list.GetItemText(self.currentItem)) @@ -176,7 +258,13 @@ class TestListCtrlPanel(wxPanel): tPopupID3 = 2 tPopupID4 = 3 tPopupID5 = 5 - menu.Append(tPopupID1, "One") + + # Show how to put an icon in the menu + item = wxMenuItem(menu, tPopupID1,"One") + if wxPlatform == '__WXMSW__': + item.SetBitmap(images.getSmilesBitmap()) + + menu.AppendItem(item) menu.Append(tPopupID2, "Two") menu.Append(tPopupID3, "Three") menu.Append(tPopupID4, "DeleteAllItems") @@ -192,6 +280,8 @@ class TestListCtrlPanel(wxPanel): def OnPopupOne(self, event): self.log.WriteText("Popup one\n") + print "FindItem:", self.list.FindItem(-1, "Billy Joel") + print "FindItemData:", self.list.FindItemData(-1, 20) def OnPopupTwo(self, event): self.log.WriteText("Popup two\n") @@ -226,19 +316,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. - -"""