X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/cdcb4b0166aefdd382d20e7ff3b5cb217ba54ba8..8d0e873f670cab8e7bc8df902abed6ebc17dd09d:/src/dolphindetailsview.cpp diff --git a/src/dolphindetailsview.cpp b/src/dolphindetailsview.cpp index 4c4102e8b..2bb145cc4 100644 --- a/src/dolphindetailsview.cpp +++ b/src/dolphindetailsview.cpp @@ -31,10 +31,14 @@ #include #include +#include +#include DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* controller) : QTreeView(parent), - m_controller(controller) + m_controller(controller), + m_rubberBand(0), + m_origin() { Q_ASSERT(controller != 0); @@ -46,6 +50,7 @@ DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* contr setDragDropMode(QAbstractItemView::DragDrop); setDropIndicatorShown(false); + setMouseTracking(true); viewport()->setAttribute(Qt::WA_Hover); const ViewProperties props(controller->url()); @@ -69,7 +74,10 @@ DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* contr } connect(this, SIGNAL(activated(const QModelIndex&)), controller, SLOT(triggerItem(const QModelIndex&))); - + connect(this, SIGNAL(entered(const QModelIndex&)), + this, SLOT(slotEntered(const QModelIndex&))); + connect(this, SIGNAL(viewportEntered()), + controller, SLOT(emitViewportEntered())); connect(controller, SIGNAL(zoomIn()), this, SLOT(zoomIn())); connect(controller, SIGNAL(zoomOut()), @@ -90,7 +98,8 @@ DolphinDetailsView::DolphinDetailsView(QWidget* parent, DolphinController* contr } DolphinDetailsView::~DolphinDetailsView() -{} +{ +} bool DolphinDetailsView::event(QEvent* event) { @@ -141,9 +150,39 @@ void DolphinDetailsView::contextMenuEvent(QContextMenuEvent* event) m_controller->triggerContextMenuRequest(event->pos()); } +void DolphinDetailsView::mousePressEvent(QMouseEvent* event) +{ + QTreeView::mousePressEvent(event); + + if (event->button() == Qt::LeftButton) { + // initialize rubberband for the selection + if (m_rubberBand == 0) { + m_rubberBand = new QRubberBand(QRubberBand::Rectangle, viewport()); + } + + const QPoint pos(contentsPos()); + m_origin = event->pos(); + m_origin.setX(m_origin.x() + pos.x()); + m_origin.setY(m_origin.y() + pos.y()); + updateRubberBandGeometry(); + m_rubberBand->show(); + } +} + +void DolphinDetailsView::mouseMoveEvent(QMouseEvent* event) +{ + QTreeView::mouseMoveEvent(event); + if (m_rubberBand != 0) { + updateRubberBandGeometry(); + } +} + void DolphinDetailsView::mouseReleaseEvent(QMouseEvent* event) { QTreeView::mouseReleaseEvent(event); + if (m_rubberBand != 0) { + m_rubberBand->hide(); + } m_controller->triggerActivation(); } @@ -152,6 +191,9 @@ void DolphinDetailsView::dragEnterEvent(QDragEnterEvent* event) if (event->mimeData()->hasUrls()) { event->acceptProposedAction(); } + if (m_rubberBand != 0) { + m_rubberBand->hide(); + } } void DolphinDetailsView::dropEvent(QDropEvent* event) @@ -188,6 +230,28 @@ void DolphinDetailsView::synchronizeSortingState(int column) m_controller->indicateSortOrderChange(sortOrder); } +void DolphinDetailsView::slotEntered(const QModelIndex& index) +{ + const QPoint pos = viewport()->mapFromGlobal(QCursor::pos()); + const int nameColumnWidth = header()->sectionSize(KDirModel::Name); + if (pos.x() < nameColumnWidth) { + m_controller->emitItemEntered(index); + } + else { + m_controller->emitViewportEntered(); + } +} + +void DolphinDetailsView::updateRubberBandGeometry() +{ + if (m_rubberBand != 0) { + const QPoint pos(contentsPos()); + const QPoint origin(m_origin.x() - pos.x(), m_origin.y() - pos.y()); + const QPoint dest(viewport()->mapFromGlobal(QCursor::pos())); + m_rubberBand->setGeometry(QRect(origin, dest).normalized()); + } +} + void DolphinDetailsView::zoomIn() { if (isZoomInPossible()) { @@ -240,4 +304,22 @@ void DolphinDetailsView::updateDecorationSize() doItemsLayout(); } +QPoint DolphinDetailsView::contentsPos() const +{ + // implementation note: the horizonal position is ignored currently, as no + // horizontal scrolling is done anyway during a selection + const QScrollBar* scrollbar = verticalScrollBar(); + Q_ASSERT(scrollbar != 0); + + const int maxHeight = maximumViewportSize().height(); + const int height = scrollbar->maximum() - scrollbar->minimum() + 1; + const int visibleHeight = model()->rowCount() + 1 - height; + if (visibleHeight <= 0) { + return QPoint(0, 0); + } + + const int y = scrollbar->sliderPosition() * maxHeight / visibleHeight; + return QPoint(0, y); +} + #include "dolphindetailsview.moc"