QTreeView 的 PyQt 工具提示

PyQt ToolTip for QTreeView

请解释如何为 QTreeView 中的每个项目启用和显示工具提示。我找到了代码示例 class TreeModel(QAbstractItemModel),但由于我的初学者水平,我无法理解如何将其应用到我的需要中。

工具提示的数据应取自字典 data_for_tree.

中键 "note" 的值
#!/usr/bin/env python -tt
# -*- coding: utf-8 -*-

from PyQt5.QtGui import *
from PyQt5.QtCore import *
from PyQt5.QtWidgets import *

import sys
reload(sys)
sys.setdefaultencoding('utf8')

data_for_tree = {"tomato":{"color":"red","ammount":"10", "note":"a note for tomato"},"banana":{"color":"yellow","ammount":"1", "note":"b note for banana"}, "some fruit":{"color":"unknown","ammount":"100", "note":"some text"}}

class TreeModel(QAbstractItemModel):

    def data(self, index, role=Qt.DisplayRole):
        #...
        if role == Qt.ToolTipRole:
            return 'ToolTip'

    def flags(self, index):
        if not index.isValid():
            return Qt.NoItemFlags # 0
        return Qt.ItemIsSelectable # or Qt.ItemIsEnabled            

class ProxyModel(QSortFilterProxyModel):

    def __init__(self, parent=None):
        super(ProxyModel, self).__init__(parent)

    def lessThan(self, left, right):
        leftData = self.sourceModel().data(left)
        rightData = self.sourceModel().data(right)
        try:
            return float(leftData) < float(rightData)
        except ValueError:
            return leftData < rightData

class MainFrame(QWidget):
    def __init__(self):
        QWidget.__init__(self)

        self.MyTreeView = QTreeView()
        self.MyTreeViewModel = QStandardItemModel()
        self.MyTreeView.setModel(self.MyTreeViewModel)
        self.most_used_cat_header = ['Name', "ammount", "color"]
        self.MyTreeViewModel.setHorizontalHeaderLabels(self.most_used_cat_header)
        self.MyTreeView.setSortingEnabled(True)
        self.MyTreeView_Fill()

        MainWindow = QHBoxLayout(self)    
        MainWindow.addWidget(self.MyTreeView)
        self.setLayout(MainWindow)

    def MyTreeView_Fill(self):
        for k in data_for_tree:
            name = QStandardItem(k)
            ammount = QStandardItem(data_for_tree[k]["ammount"])
            note = QStandardItem(data_for_tree[k]["color"])
            tooltip = data_for_tree[k]["note"]
            item = (name, ammount, note)
            self.MyTreeViewModel.appendRow(item)
        self.MyTreeView.sortByColumn(1, Qt.DescendingOrder)
        proxyModel = ProxyModel(self)
        proxyModel.setSourceModel(self.MyTreeViewModel)
        self.MyTreeView.setModel(proxyModel)

        c = 0
        while c < len(self.most_used_cat_header):
            self.MyTreeView.resizeColumnToContents(c)
            c=c+1

if __name__ == "__main__":
    app = QApplication(sys.argv)
    main = MainFrame()
    main.show()
    main.move(app.desktop().screen().rect().center() - main.rect().center())
sys.exit(app.exec_())

因为您正在使用 QStandardItemQStandardItemModel classes(这是我推荐的!),您不需要为 TreeModel 操心class 你找到了。很少需要创建自己的模型,但出于某种原因,教程通常鼓励您这样做。如果您发现某些鼓励您使用 subclass QAbstractItemModel 的东西,我建议您先检查堆栈溢出,看看是否有更简单的方法来做到这一点!在这种情况下,有一种非常简单的方法来添加工具提示。

如果您查看 C++ 文档(我经常发现它比 PyQt 文档更有用,可以找出可用的方法),您会看到 QStandardItem 有一个名为 setToolTip() 的方法.

所以您需要做的就是对添加到模型的每个项目调用此方法。例如,在 MyTreeView_Fill 方法的循环内:

name = QStandardItem(k)
ammount = QStandardItem(data_for_tree[k]["ammount"])
note = QStandardItem(data_for_tree[k]["color"])
tooltip = data_for_tree[k]["note"]
name.setToolTip(tooltip)
ammount.setToolTip(tooltip)
note.setToolTip(tooltip)

在这里,我将行中每个单元格的工具提示设置为相同(名称、数量和备注),但您可以轻松更改它,使其中一个单元格具有不同的工具提示(希望这是显而易见的)怎么做)