Python PyQt5:QListWidget不接受删除

2024-04-27 00:14:22 发布

您现在位置:Python中文网/ 问答频道 /正文

我尝试创建一个简单的QListWidget,它接受放入其中的文本。无法工作。拖放事件甚至不会被触发,而拖动事件则是另一方面。 谁能给我指出正确的方向吗?我做错什么了?在

提前谢谢。在

import sys
from PyQt5.QtWidgets import QApplication, QWidget, QPushButton,  QLineEdit, QLabel, QListWidget
from PyQt5.QtGui import QIcon
from PyQt5.QtCore import pyqtSlot

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 = CustomLabel(self)
        listwidget.move(130,15)

        self.show()


class CustomLabel(QListWidget):

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

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


    def dropEvent(self, e):
        print("dropped")

        self.addItem(event.mimeData().text())

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

Tags: fromimportselfappinitdefsys事件
3条回答

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

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)

看起来您的代码是基于this example。在

主要区别在于您的CustomLabel继承了QListWidget,而不是{}。不幸的是,QListWidget继承了QAbstractScrollArea,并且与滚动区域相关联的viewport小部件将接收各种拖放事件,而不是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:

你可能还需要添加。。。在

^{pr2}$

太棒了。现在这是可行的。 非常感谢你的帮助。 所以这就是全部代码:

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_())

相关问题 更多 >