PyQt6 QTreeView Drag & Drop-Indikator wird nach dem Überschreiben von Drag-Ereignissen nicht angezeigtPython

Python-Programme
Guest
 PyQt6 QTreeView Drag & Drop-Indikator wird nach dem Überschreiben von Drag-Ereignissen nicht angezeigt

Post by Guest »

Ich versuche, Drag-and-Drop-Funktionalität in einem QTreeView-Widget in PyQt6 zu implementieren. Ich habe die Drag-and-Drop-Unterstützung mithilfe von setDragEnabled(True), setAcceptDrops(True) und setDropIndicatorShown(True) aktiviert, um den Drop-Indikator beim Ziehen von Elementen anzuzeigen.
Nach dem Überschreiben der integrierten Drag-and-Drop-Ereignisfunktionen (

Code: Select all

dragEnterEvent
, dragMoveEvent und dropEvent) wird der Drop-Indikator (die Linie zwischen Zeilen, an der das gezogene Element abgelegt werden kann) nicht mehr angezeigt.
Wie kann ich die Drop-Anzeige zwischen Elementen wiederherstellen oder richtig anzeigen, nachdem ich die Drag-and-Drop-Ereignisfunktionen in PyQt6s QTreeView überschrieben habe?
Hier ist der Code, den ich bisher habe:

Code: Select all

from PyQt6 import QtCore, QtGui, QtWidgets

class ObjectTree(QtWidgets.QTreeView):
def __init__(self):
super().__init__()

self.model = QtGui.QStandardItemModel()
self.setModel(self.model)

# Enable drag and drop
self.setDragEnabled(True)
self.setAcceptDrops(True)
self.setDropIndicatorShown(True)  # Show drop indicator

self._populate_tree()

def _populate_tree(self):
root_item = QtGui.QStandardItem('Root')
self.model.appendRow(root_item)
for i in range(10):
child_item = QtGui.QStandardItem(f'Child {i + 1}')
root_item.appendRow(child_item)

def dragEnterEvent(self, event):
if event.mimeData().hasFormat('application/x-item'):
event.acceptProposedAction()
else:
event.ignore()

def dragMoveEvent(self, event):
if event.mimeData().hasFormat('application/x-item'):
event.acceptProposedAction()
else:
event.ignore()

def dropEvent(self, event):
if event.mimeData().hasFormat('application/x-item'):
data = event.mimeData().data('application/x-item')
stream = QtCore.QDataStream(data, QtCore.QIODevice.OpenModeFlag.ReadOnly)
item_name = stream.readQString()
print(f"Dropped item: {item_name}")
event.acceptProposedAction()

def startDrag(self, event):
selected_indexes = self.selectedIndexes()
if selected_indexes:
selected_item = self.model.itemFromIndex(selected_indexes[0])
mime_data = QtCore.QMimeData()
data = QtCore.QByteArray()
stream = QtCore.QDataStream(data, QtCore.QDataStream.OpenModeFlag.WriteOnly)
stream.writeQString(selected_item.text())
mime_data.setData('application/x-item', data)

drag = QtGui.QDrag(self)
drag.setMimeData(mime_data)
drag.exec(event)

class MainWindow(QtWidgets.QMainWindow):
def __init__(self):
super().__init__()

self.object_tree = ObjectTree()
self.setCentralWidget(self.object_tree)

self.setWindowTitle("PyQt6 Drag and Drop Example")
self.setGeometry(100, 100, 600, 400)

if __name__ == "__main__":
app = QtWidgets.QApplication([])
window = MainWindow()
window.show()
app.exec()

Quick Reply

Change Text Case: 
   
  • Similar Topics
    Replies
    Views
    Last post