我试图创建一个简单的QListWidget来接受放入其中的文本。无法使其发挥作用。甚至没有触发drop事件,另一方面是drag事件。 任何人都能指出我正确的方向吗?我做错了什么?
提前致谢。
cameraPhotoOutput.capturePhoto(with: photoSettings, delegate: self)
答案 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_())