【发布时间】:2016-02-27 14:44:23
【问题描述】:
我正在尝试创建一个 QListWidget,其中包含自定义小部件,每个小部件都包含一个拖动按钮。这个想法是 QListWidgetItem 只能在按下其中称为“拖动”的按钮时拖放。释放鼠标/按钮后,QListWidgetItem 将落入其位置。整个事情应该就像普通的 QListWidget 一样,只是鼠标按下的位置必须在名为“拖动”的按钮上。
我目前的方法是在初始化时将所有 QListWidgetItem 标志设置为 ~Qt.ItemIsDragEnabled,然后在单击按钮时将其重新打开。然后在离开小部件时,我关闭拖动功能。
这是演示我在哪里的工作代码。显然这不是我真正想要的,但我不知道如何一键将“拖动”按钮内的鼠标按下事件传递到 QListWidgetItem 后面。
import sys
import os
from PyQt4 import QtGui
from PyQt4.QtCore import *
from PyQt4.QtGui import *
class DragArea(QFrame):
"""docstring for DragButton"""
def __init__(self, parent=None, text='Test', index=None):
super(DragArea, self).__init__()
self.parent = parent
self.index = index
self.layout = QHBoxLayout()
self.setLayout(self.layout)
self.label = QLabel()
self.button = QPushButton()
self.label.setText(text)
self.button.setText('Drag')
self.layout.addWidget(self.label)
self.layout.addWidget(self.button)
self.button.pressed.connect(self.drag)
def drag(self):
item = self.parent.bodyMap[self.index]
item.setFlags(
Qt.ItemIsSelectable |
Qt.ItemIsEnabled |
Qt.ItemIsDragEnabled
)
def leaveEvent(self, event):
item = self.parent.bodyMap[self.index]
item.setFlags(
item.flags() &
~Qt.ItemIsSelectable &
~Qt.ItemIsEnabled &
~Qt.ItemIsDragEnabled
)
class QuoteArea(QListWidget):
def __init__(self, parent=None):
super(QuoteArea, self).__init__()
self.bodyMap = {}
self.setStyleSheet("""
QListWidget {
background: gray;
}
QListWidget::item:selected {
background: None;
}
""")
self.setDragDropMode(QAbstractItemView.InternalMove)
self.setDefaultDropAction(Qt.MoveAction)
self.setDragDropOverwriteMode(False)
self.setAcceptDrops(True)
self.setDropIndicatorShown(True)
self.setDragEnabled(True)
self.setSelectionRectVisible(False)
self.setResizeMode(QListView.Adjust)
self.setGeometry(30, 40, 400, 500)
for a in xrange(5):
self.addQuote(a)
def addQuote(self, index):
text = 'Lorum ipsum ' + str(index)
widget = DragArea(text=text, parent=self, index=index)
item = QListWidgetItem()
item.setFlags(item.flags() &
~Qt.ItemIsSelectable &
~Qt.ItemIsEnabled &
~Qt.ItemIsDragEnabled
)
self.bodyMap[index] = item
item.setSizeHint(
QSize(item.sizeHint().width(), widget.sizeHint().height())
)
self.addItem(item)
self.setItemWidget(item, widget)
def main():
app = QtGui.QApplication(sys.argv)
ex = QuoteArea()
ex.show()
sys.exit(app.exec_())
if __name__ == '__main__':
main()
【问题讨论】:
标签: python qt drag-and-drop pyqt qlistwidget