基于鼠标位置的PyQt多个上下文菜单

5 投票
1 回答
6676 浏览
提问于 2025-04-17 00:22

我有一个窗口,里面有多个表格,使用的是QTableWidget(PyQt)。我通过右键点击创建了一个弹出菜单,运行得很好。

不过,我需要根据鼠标右键点击时,鼠标悬停在哪个表格上,来创建不同的弹出菜单。请问我该如何知道鼠标悬停的是哪个表格呢?

换句话说,我想实现一个方法,根据鼠标的位置来显示特定的上下文菜单。

我使用的是Python和PyQt。

我的弹出菜单的开发方式类似于这段代码(PedroMorgan在Qt和上下文菜单中的回答):

class Foo( QtGui.QWidget ):

    def __init__(self):
        QtGui.QWidget.__init__(self, None)

        # Toolbar
        toolbar = QtGui.QToolBar()

        # Actions
        self.actionAdd = toolbar.addAction("New", self.on_action_add)
        self.actionEdit = toolbar.addAction("Edit", self.on_action_edit)
        self.actionDelete = toolbar.addAction("Delete", self.on_action_delete)

        # Tree
        self.tree = QtGui.QTreeView()
        self.tree.setContextMenuPolicy( Qt.CustomContextMenu )
        self.connect(self.tree, QtCore.SIGNAL('customContextMenuRequested(const QPoint&)'), self.on_context_menu)

        # Popup Menu
        self.popMenu = QtGui.QMenu( self )
        self.popMenu.addAction( self.actionEdit )
        self.popMenu.addAction( self.actionDelete )
        self.popMenu.addSeparator()
        self.popMenu.addAction( self.actionAdd )

    def on_context_menu(self, point):
        self.popMenu.exec_( self.tree.mapToGlobal(point) )

1 个回答

7

一种方法是创建一个QTableWidget的子类,然后实现你自己的contextMenuEvent方法。这样,你就可以为每个实例设置不同的右键菜单事件处理方式。下面是一个简单的例子。

from PyQt4 import QtGui, QtCore
import sys

class MyTableWidget(QtGui.QTableWidget):

    def __init__(self, name='Table1', parent=None):
        super(MyTableWidget, self).__init__(parent)
        self.name = name

    def contextMenuEvent(self, event):
        menu = QtGui.QMenu(self)

        Action = menu.addAction("I am a " + self.name + " Action")
        Action.triggered.connect(self.printName)

        menu.exec_(event.globalPos())

    def printName(self):
        print "Action triggered from " + self.name


class Main(QtGui.QWidget):
    def __init__(self, parent=None):
        super(Main, self).__init__(parent)

        layout = QtGui.QVBoxLayout(self)

        self.table1 = MyTableWidget(name='Table1', parent=self)
        self.table2 = MyTableWidget(name='Table2', parent=self)

        layout.addWidget(self.table1)
        layout.addWidget(self.table2)
        self.setLayout(layout)


if __name__ == '__main__':

    app = QtGui.QApplication(sys.argv)
    main = Main()
    main.show()

    app.exec_()

撰写回答