Python PyQt5:QListWidget不接受drop

时间:2017-03-16 15:31:50

标签: python drag-and-drop qt5 pyqt5 qlistwidget

我试图创建一个简单的QListWidget来接受放入其中的文本。无法使其发挥作用。甚至没有触发drop事件,另一方面是drag事件。 任何人都能指出我正确的方向吗?我做错了什么?

提前致谢。

cameraPhotoOutput.capturePhoto(with: photoSettings, delegate: self) 

3 个答案:

答案 0 :(得分:1)

默认情况下,QListWidget不处理已删除的文本,因此您必须重新实现mime-data处理,如下所示:

class CustomLabel(QListWidget):    
    def __init__(self, parent):
        super().__init__(parent)
        self.setAcceptDrops(True)

    def mimeTypes(self):
        mimetypes = super().mimeTypes()
        mimetypes.append('text/plain')
        return mimetypes

    def dropMimeData(self, index, data, action):
        if data.hasText():
            self.addItem(data.text())
            return True
        else:
            return super().dropMimeData(index, data, action)

答案 1 :(得分:0)

看起来您的代码基于this example

主要区别在于您的CustomLabel继承自QListWidget而不是QLabel。不幸的是QListWidget继承自QAbstractScrollArea,它是与该滚动区域相关联的视口窗口小部件,它将接收各种拖放事件 - 而不是QListWidget本身。

您最好的选择可能是在视口上安装事件过滤器....

class CustomLabel(QListWidget):
    def __init__(self, parent):
        super().__init__(parent)
        self.setAcceptDrops(True)

        # Install the event filter.
        self.viewport().installEventFilter(self)

    def dragEnterEvent(self, e):
        if e.mimeData().hasFormat('text/plain'):
            print("dragged")
            e.accept()
        else:
            e.ignore()

    def eventFilter (self, obj, event):
        if obj == self.viewport():
            print("event")
            if event.type() == QEvent.DragMove:
                print("moved")
                event.accept()

                # Your drag enter event processing code goes here
                return True
            if event.type() == QEvent.Drop:
                print("dropped")
                event.accept()

                # Your drop event processing code goes here
                return True
        return super(CustomLabel, self).eventFilter(obj, event)

修改1:

您可能还需要添加...

from PyQt5.QtCore import QEvent

答案 2 :(得分:0)

惊人。现在有效。 非常感谢你的帮助。 这就是整个代码组合在一起的:

import sys
from PyQt5.QtWidgets import QApplication, QWidget,  QLineEdit, QListWidget


class App(QWidget):

    def __init__(self):
        super().__init__()
        self.title = 'PyQt5 drag and drop'
        self.left = 500
        self.top = 400
        self.width = 400
        self.height = 250
        self.initUI()

    def initUI(self):
        self.setWindowTitle(self.title)
        self.setGeometry(self.left, self.top, self.width, self.height)

        editBox = QLineEdit('Drag this', self)
        editBox.setDragEnabled(True)
        editBox.move(10, 10)
        editBox.resize(100,32)

        listwidget = CustomList(self)
        listwidget.move(130,15)

        self.show()


class CustomList(QListWidget):

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

    def mimeTypes(self):
        mimetypes = super().mimeTypes()
        mimetypes.append('text/plain')
        return mimetypes

    def dropMimeData(self, index, data, action):
        if data.hasText():
            self.addItem(data.text())
            return True
        else:
            return super().dropMimeData(index, data, action)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = App()
    sys.exit(app.exec_())