龙空技术网

wxPython -高级控件之列表框ListBox

爱好史地的coder 117

前言:

当前你们对“css树形控件”大概比较看重,咱们都需要知道一些“css树形控件”的相关知识。那么小编同时在网上收集了一些关于“css树形控件””的相关文章,希望看官们能喜欢,朋友们快快来学习一下吧!

实战wxPython系列-039

wxPythontigo提供了一些高级控件。例如,树形控件、HTML窗口、网格控件、列表控件、或具有高级样式功能的编辑器等。

一、wx.ListBox列表框

wx.ListBox列表框控件从一个字符串列表中选择一个或者多个字符串。所选字符串显示在一个可以滚动的列表框中,所选中的字符串将特别标记。列表框可以是单选 (如果选择了其中的一个项,则清除先前的选择项)或者多重选择(选择一个项的时,不影响对其他项的选择)。

列表框元素从0开始编号,虽然元素的最大数量是无限的,但通常最好使用虚拟控件,不需要一次性将所有项添加到其中。由于这个控件没有做优化,比如在wx.dataview.DataViewCtrl或者使用LC_VIRTUAL样式的wx.ListCtrl时,需要加载超过上百的项时,性能会有所影响。

注意,列表框不支持除制表符以外的控制字符。

wx.ListBox支持的窗口样式:

wx.LB_SINGLE:单选列表。wx.LB_MULTIPLE:多选列表。wx.LB_EXTENDED:扩展选择列表:用户可以使用SHIFT或CTRL键以及光标移动键或鼠标来扩展选择。wx.LB_HSCROLL:如果内容太多,创建水平滚动条(仅限Windows)。wx.LB_ALWAYS_SB:始终显示垂直滚动条。wx.LB_NEEDED_SB:只在需要时创建垂直滚动条。wx.LB_NO_SB:不创建垂直滚动条(仅限于wxMSW和wxGTK)。wx.LB_SORT:列表框内容按字母顺序排序。

注意:LB_SINGLE, LB_MULTIPLE和LB_EXTENDED样式是互斥的,最多可以指定其中一个样式(单选是默认设置)。

wx.ListBox发出的事件:

EVT_LISTBOX:当列表中的项被选中或选择发生变化时,处理wx.EVT_LISTBOX事件。EVT_LISTBOX_DCLICK:当双击列表框时,处理wx.EVT_LISTBOX_DCLICK事件。

wx.ListBox常用方法:

Deselect(self, n):取消选择列表框中的项(只适用于多选择列表框)。EnsureVisible(self, n):确保当前显示具有给定索引的项。这个方法只在必要时滚动列表框,如果这个项已经显示,它不会做任何事情。FindString(self, string, caseSensitive=False):查找与给定字符串匹配的项。GetCount(self):返回控件中的项数。GetCountPerPage(self):返回可以放入列表框垂直可见区域的项数量。如果无法确定每页的条目数,则返回-1。GetSelection(self):返回所选项的索引,如果没有选择项,则返回NOT_FOUND。GetSelections(self):用当前选定项的位置填充整数数组GetString(self, n):返回具有给定索引的项的标签。索引必须是有效的,即小于GetCount返回的值,否则会触发断言。值得注意的是,如果控件为空,则不能调用此函数。GetTopItem(self):返回最上面可见项的索引。如果该方法没有为当前平台实现,则返回NOT_FOUND。HitTest (self, point):返回位于point上的项,如果没有项位于point上,则返回NOT_FOUND。InsertItems(self, items, pos):在指定位置之前插入给定数量的字符串。IsSelected(self, n):确定是否选择某项。IsSorted(self):如果列表框为LB_SORT样式,则返回True。此方法主要仅用于内部使用。SetFirstItem (self, string):将指定的项设置为第一个可见项。SetItemBackgroundColour(self, item, c):如果wx.LB_OWNERDRAW标志被设置,在列表框中设置一个项的背景颜色(仅对MSW有效)。SetItemFont(self, item, f):如果wx.LB_OWNERDRAW标志被设置,在列表框中设置一个项的前景颜色(仅对MSW有效)。SetSelection(self, n):将选定项设置为给定项n,如果n == NOT_FOUND则完全删除选定项。注意,这不会触发任何命令事件,也不会取消控件中支持多个选择的任何其他项。SetString(self, n, string):为给定的项设置标签。

图1:wx.ListBox类继承关系

二、wx.ListBox演示

#列表框(wx.ListBox)import wxclass SampleListBox(wx.Frame):    def __init__(self, *args, **kw):        super(SampleListBox, self).__init__(*args, **kw)        self.InitUi()    def InitUi(self):        #设置标题        self.SetTitle("实战wxPython: ListBox演示")        #设置窗口尺寸        self.SetSize(400, 240)        panel = wx.Panel(self)        #水平布局        hbox = wx.BoxSizer(wx.HORIZONTAL)        # 添加一个列表框        self.listbox = wx.ListBox(panel)        hbox.Add(self.listbox, wx.ID_ANY, wx.EXPAND | wx.ALL, 20)        # 按钮面板        btnPanel = wx.Panel(panel)        vbox = wx.BoxSizer(wx.VERTICAL)        newButon = wx.Button(btnPanel, wx.ID_ANY, "新建", size = (90, 30))        renButton = wx.Button(btnPanel, wx.ID_ANY, "重命名", size = (90, 30))        delButton = wx.Button(btnPanel, wx.ID_ANY, "删除", size = (90, 30))        clrButton = wx.Button(btnPanel, wx.ID_ANY, "清理", size = (90, 30))        newButon.Bind(wx.EVT_BUTTON, self.NewItem)        renButton.Bind(wx.EVT_BUTTON, self.OnRename)        delButton.Bind(wx.EVT_BUTTON, self.OnDelete)        clrButton.Bind(wx.EVT_BUTTON, self.OnClear)        self.Bind(wx.EVT_LISTBOX_DCLICK, self.OnRename)        vbox.Add((-1, 20)) #距离顶端20像素        vbox.Add(newButon)        vbox.Add(renButton, 0, wx.TOP, 5)        vbox.Add(delButton, 0, wx.TOP, 5)        vbox.Add(clrButton, 0, wx.TOP, 5)        btnPanel.SetSizer(vbox)        hbox.Add(btnPanel, 0.6, wx.EXPAND | wx.RIGHT, 20)        panel.SetSizer(hbox)        self.Centre()    def NewItem(self, e):        text = wx.GetTextFromUser("输入一个新项", "插入对话框")        if text != "":            self.listbox.Append(text)    def OnRename(self, e):        sel = self.listbox.GetSelection()        text = self.listbox.GetString(sel)        renamed = wx.GetTextFromUser("项重命名", "重命名对话框", text)        if renamed != "":            self.listbox.Delete(sel)            item_id = self.listbox.Insert(renamed, sel)            self.listbox.SetSelection(item_id)    def OnDelete(self, e):        sel = self.listbox.GetSelection()        if sel != -1:            self.listbox.Delete(sel)    def OnClear(self, e):        self.listbox.Clear()def main():    app = wx.App()    sample = SampleListBox(None)    sample.Show()    app.MainLoop()if __name__ == "__main__":    main()

这个例子展示了如何从wx.ListBox中添加、修改和删除项。

self.listbox = wx.ListBox(panel) hbox.Add(self.listbox, wx.ID_ANY, wx.EXPAND | wx.ALL, 20)

创建一个空的wx.ListBox。设置列表框边框距离20px。

self.Bind(wx.EVT_LISTBOX_DCLICK, self.OnRename)

绑定wx. EVT_LISTBOX_DCLICK事件到方法OnRename(),这样,如果双击列表框中的特定元素,就会显示重命名对话框。

def NewItem(self, e):        text = wx.GetTextFromUser("输入一个新项", "插入对话框")        if text != "":            self.listbox.Append(text)

通过单击新建按钮调用NewItem()方法。在NuwItem方法中,使用包装器wx.GetTextFromUser()方法显示一个wx.TextEntryDialog。将对话框中输入的文本返回给文本变量。如果文本不是空的,我们用append()方法将它添加到列表框中。

if renamed != "":       self.listbox.Delete(sel)       item_id = self.listbox.Insert(renamed, sel)       self.listbox.SetSelection(item_id)

通过删除项并在同一位置插入新项来重命名项。将选择设置回已修改的项。

def OnDelete(self, e):        sel = self.listbox.GetSelection()        if sel != -1:            self.listbox.Delete(sel)

要删除一个项,通过调用GetSelection()方法找到所选项的索引。然后使用delete()方法删除该项。

def OnClear(self, e):        self.listbox.Clear()

调用Clear()方法清除整个列表框。

图2:wx.ListBox演示

三、wx.CheckListBox复选列表框

wx.CheckListBox是wx.ListBox的派生类,继承了它的功能,它在每个选项上额外显示一个复选框。

wx.CheckListBox发出的事件:

EVT_CHECKLISTBOX:当选中或取消选中复选框中的项时,处理wx.EVT_CHECKLISTBOX事件。

wx.CkeckListBox常用方法:

Check(self, item, check=True):设置给定的项的选择状态。调用此方法不会导致触发wx.EVT_CHECKLISTBOX事件。GetCheckedItems(self):根据IsChecked返回与控件中已选择项对应的整数序列。GetCheckedStrings(self):根据GetChecked返回与控件的已选择项对应的字符串元组。GetSelections(self):返回当前选定项的索引列表。IsChecked(self, item):如果选中给定项则返回True,否则返回False。SetCheckedItems(self, indexes):如果在索引序列中找到项的索引,则设置项的已选定状态。SetCheckedStrings(self, strings):如果在字符串序列中找到项的字符串,则设置项的选定状态。

图3:wx.CheckListBox类继承关系

将节二中的演示代码:

self.listbox = wx.ListBox(panel)

修改成

self.listbox = wx.CheckListBox(panel)

运行,就可以演示使用wx.CheckListBox,效果如图4:

图4:wx.CheckListBox演示

四、本文知识点

了解和使用wx.ListBox。了解和使用wx.CheckListBox。

前一篇:wxPython - 状态栏StatusBar

欢迎关注,评论,收藏,点赞,和转发。

标签: #css树形控件