用户在Gtk.TreeView中搜索折叠行
我该如何让一个互动搜索(通过按 Ctrl-f 或 / 来启动的搜索)在 Gtk.TreeView 的折叠行中进行搜索呢?
举个例子,如果我想在下面的代码中搜索“Second in Four”,而不需要先展开“Row Four”:
from gi.repository import Gtk
class Main(Gtk.Window):
def __init__(self):
Gtk.Window.__init__(self, title="Recursive Search")
self.set_default_size(200, 200)
self.treestore = Gtk.TreeStore(str, str)
treeiter = self.treestore.append(None, ["Row One", ""])
self.treestore.append(treeiter, ["Row Two", "First in One"])
self.treestore.append(treeiter, ["Row Tree", "Second in One"])
treeiter = self.treestore.append(None, ["Row Four", ""])
self.treestore.append(treeiter, ["Row Five", "First in Four"])
self.treestore.append(treeiter, ["Row Six", "Second in Four"])
treeiter = self.treestore.append(None, ["Row Seven", ""])
self.treestore.append(treeiter, ["Row Eight", "First in Seven"])
self.treestore.append(treeiter, ["Row Nine", "Second in Seven"])
treeview = Gtk.TreeView(model=self.treestore)
renderer_text = Gtk.CellRendererText()
column_text = Gtk.TreeViewColumn(cell_renderer=renderer_text, text=0)
treeview.append_column(column_text)
column_text = Gtk.TreeViewColumn(cell_renderer=renderer_text, text=1)
treeview.append_column(column_text)
treeview.set_search_column(1)
treeview.set_headers_visible(False)
self.add(treeview)
win = Main()
win.connect("delete-event", Gtk.main_quit)
win.show_all()
Gtk.main()
1 个回答
2
你可以使用 Gtk.Treeview.set_search_equal_func()
来实现这个功能:
def __init__(self):
...
treeview.set_search_equal_func(self.search_function)
self.treeview = treeview
def search_function(self, model, column, key, rowiter):
row = model[rowiter]
if key.lower() in list(row)[column-1].lower():
return False # Search matches
# Search in child rows. If one of the rows matches, expand the row so that it will be open in later checks.
for inner in row.iterchildren():
if key.lower() in list(inner)[column-1].lower():
self.treeview.expand_to_path(row.path)
break
else:
self.treeview.collapse_row(row.path)
return True # Search does not match
我推荐你去 gnome.org 查看关于 Gtk 的文档。虽然那里的内容不是最新的,但它提供了很多 Gtk 类和函数的简单易懂的文档,方便查找。