如何拖放到QTableWidget? (PyQt的)

时间:2012-04-21 23:46:14

标签: drag-and-drop pyqt qtablewidget

我正在努力摆脱拖延工作。我希望能够从QPushButton拖放到QTableView的单元格中。我在线查看了一些教程,但似乎第一步陷入困境。以下示例从令人惊叹的zetcode教程改变: http://zetcode.com/tutorials/pyqt4/dragdrop/

使用下面的代码,当我将按钮拖到tableWidget中时,似乎会调用dragEnterEvent,但是一旦我将鼠标悬停在表上,我就会得到那个我不允许在桌子上掉落的符号,所以永远无法进入掉落事件:(

我不得不承认我对pyqt很新,所以可能会遗漏一些非常简单的东西。非常感谢我能得到的任何帮助! 干杯 戴夫

import sys
from PyQt4 import QtGui
from PyQt4 import QtCore


class Button(QtGui.QPushButton):

    def __init__(self, title, parent):
        super(Button, self).__init__(title, parent)


    def mouseMoveEvent(self, e):
        if e.buttons() != QtCore.Qt.RightButton:
            return

        mimeData = QtCore.QMimeData()
        drag = QtGui.QDrag(self)
        drag.setMimeData(mimeData)
        drag.setHotSpot(e.pos() - self.rect().topLeft())

       dropAction = drag.start(QtCore.Qt.MoveAction)


    def mousePressEvent(self, e):

        QtGui.QPushButton.mousePressEvent(self, e)
        if e.button() == QtCore.Qt.LeftButton:
            print 'press'


class MyTable(QtGui.QTableWidget):

    def __init__(self, rows, columns, parent):
        super(MyTable, self).__init__(rows, columns, parent)
        self.setAcceptDrops(True)

    def dragEnterEvent(self, e):
        print e.accept()

    def dropEvent(self, e):
        print 'blah'

        position = e.pos()
        self.button.move(position)

        e.setDropAction(QtCore.Qt.MoveAction)

        e.accept()



class Example(QtGui.QWidget):

    def __init__(self):
        super(Example, self).__init__()
        self.initUI()

    def initUI(self):
        self.setAcceptDrops(True)
        self.button = Button('Button', self)

        self.table = MyTable(2,2,self)
        self.table.setAcceptDrops(True)
        self.table.setDragEnabled(True)

        self.setWindowTitle('Click or Move')

        self.setGeometry(300, 300, 280, 150)

        layout = QtGui.QVBoxLayout()
        layout.addWidget(self.button)
        layout.addWidget(self.table)
        self.setLayout(layout)


def main():

    app = QtGui.QApplication(sys.argv)
    ex = Example()
    ex.show()
    app.exec_()  


if __name__ == '__main__':

    main()

1 个答案:

答案 0 :(得分:5)

因为您要在QTableWidget上设置拖放,所以还需要重新实现它dragMoveEvent。根据{{​​3}}:

  

对复杂小部件进行子类化   某些标准的Qt小部件提供了它们   自己支持拖放。在对这些小部件进行子类化时,它可能会   除了需要重新实现dragMoveEvent()   dragEnterEvent()和dropEvent()以防止基类   提供默认的拖放处理,并处理任何特殊的   你感兴趣的案例。

class MyTable(QtGui.QTableWidget):
    ...
    def dragMoveEvent(self, e):
        e.accept()

另外,请注意,虽然原始教程显示了如何在没有任何布局的情况下移动窗口小部件中的按钮,但您的示例现在具有由垂直布局管理的按钮。因此,self.button.move(position)无法按预期工作。虽然dropEvent应该正常启动,但是当它悬停一个单元格时你应该得到“已接受”的拖动图标。