X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/6d88d801baf44dafa11975fde1007ea53063db29..19dadee2cfd4471d795b2b72ac0541124aa505ce:/src/sidebartreeview.cpp diff --git a/src/sidebartreeview.cpp b/src/sidebartreeview.cpp index a40d26c13..f82bff37a 100644 --- a/src/sidebartreeview.cpp +++ b/src/sidebartreeview.cpp @@ -22,11 +22,13 @@ #include #include -#include -#include +#include +#include +#include SidebarTreeView::SidebarTreeView(QWidget* parent) : - QTreeView(parent) + QTreeView(parent), + m_dragging(false) { setAcceptDrops(true); setUniformRowHeights(true); @@ -70,6 +72,27 @@ void SidebarTreeView::dragEnterEvent(QDragEnterEvent* event) event->acceptProposedAction(); } QTreeView::dragEnterEvent(event); + m_dragging = true; +} + +void SidebarTreeView::dragLeaveEvent(QDragLeaveEvent* event) +{ + QTreeView::dragLeaveEvent(event); + + // TODO: remove this code when the issue #160611 is solved in Qt 4.4 + m_dragging = false; + setDirtyRegion(m_dropRect); +} + +void SidebarTreeView::dragMoveEvent(QDragMoveEvent* event) +{ + QTreeView::dragMoveEvent(event); + + // TODO: remove this code when the issue #160611 is solved in Qt 4.4 + const QModelIndex index = indexAt(event->pos()); + setDirtyRegion(m_dropRect); + m_dropRect = visualRect(index); + setDirtyRegion(m_dropRect); } void SidebarTreeView::dropEvent(QDropEvent* event) @@ -84,6 +107,24 @@ void SidebarTreeView::dropEvent(QDropEvent* event) emit urlsDropped(urls, index); } } + m_dragging = false; +} + +void SidebarTreeView::paintEvent(QPaintEvent* event) +{ + QTreeView::paintEvent(event); + + if (m_dragging) { + // TODO: remove this code when the issue #160611 is solved in Qt 4.4 + QPainter painter(viewport()); + painter.save(); + QBrush brush(palette().brush(QPalette::Normal, QPalette::Highlight)); + QColor color = brush.color(); + color.setAlpha(64); + brush.setColor(color); + painter.fillRect(m_dropRect, brush); + painter.restore(); + } } #include "sidebartreeview.moc"