X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/c91365ab8d7582255aa0de8f403ec0787446a74f..ec00f379dc42b00a64ab1af25bb4bb1a06bd7449:/src/dolphincontroller.cpp diff --git a/src/dolphincontroller.cpp b/src/dolphincontroller.cpp index c39776349..0f308481f 100644 --- a/src/dolphincontroller.cpp +++ b/src/dolphincontroller.cpp @@ -19,8 +19,14 @@ #include "dolphincontroller.h" +#include + DolphinController::DolphinController(QObject* parent) : - QObject(parent) + QObject(parent), + m_showPreview(false), + m_showAdditionalInfo(false), + m_zoomInPossible(false), + m_zoomOutPossible(false) { } @@ -28,11 +34,18 @@ DolphinController::~DolphinController() { } -void DolphinController::triggerContextMenuRequest(const QPoint& pos, - const QPoint& globalPos) +void DolphinController::setUrl(const KUrl& url) +{ + if (m_url != url) { + m_url = url; + emit urlChanged(url); + } +} + +void DolphinController::triggerContextMenuRequest(const QPoint& pos) { emit activated(); - emit requestContextMenu(pos, globalPos); + emit requestContextMenu(pos); } void DolphinController::triggerActivation() @@ -40,6 +53,14 @@ void DolphinController::triggerActivation() emit activated(); } +void DolphinController::indicateDroppedUrls(const KUrl::List& urls, + const QModelIndex& index, + QWidget* source) +{ + emit urlsDropped(urls, index, source); +} + + void DolphinController::indicateSortingChange(DolphinView::Sorting sorting) { emit sortingChanged(sorting); @@ -50,14 +71,72 @@ void DolphinController::indicateSortOrderChange(Qt::SortOrder order) emit sortOrderChanged(order); } +void DolphinController::setShowPreview(bool show) +{ + if (m_showPreview != show) { + m_showPreview = show; + emit showPreviewChanged(show); + } +} + +void DolphinController::setShowAdditionalInfo(bool show) +{ + if (m_showAdditionalInfo != show) { + m_showAdditionalInfo = show; + emit showAdditionalInfoChanged(show); + } +} + +void DolphinController::triggerZoomIn() +{ + emit zoomIn(); +} + +void DolphinController::triggerZoomOut() +{ + emit zoomOut(); +} + +void DolphinController::drawHoverIndication(QWidget* widget, + const QRect& bounds, + const QBrush& brush) +{ + QPainter painter(widget); + painter.save(); + QBrush blendedBrush(brush); + QColor color = blendedBrush.color(); + color.setAlpha(64); + blendedBrush.setColor(color); + + const int radius = 10; + QPainterPath path(QPointF(bounds.left(), bounds.top() + radius)); + path.quadTo(bounds.left(), bounds.top(), bounds.left() + radius, bounds.top()); + path.lineTo(bounds.right() - radius, bounds.top()); + path.quadTo(bounds.right(), bounds.top(), bounds.right(), bounds.top() + radius); + path.lineTo(bounds.right(), bounds.bottom() - radius); + path.quadTo(bounds.right(), bounds.bottom(), bounds.right() - radius, bounds.bottom()); + path.lineTo(bounds.left() + radius, bounds.bottom()); + path.quadTo(bounds.left(), bounds.bottom(), bounds.left(), bounds.bottom() - radius); + path.closeSubpath(); + + painter.setRenderHint(QPainter::Antialiasing); + painter.fillPath(path, blendedBrush); + painter.restore(); +} + void DolphinController::triggerItem(const QModelIndex& index) { emit itemTriggered(index); } -void DolphinController::indicateSelectionChange() +void DolphinController::emitItemEntered(const QModelIndex& index) +{ + emit itemEntered(index); +} + +void DolphinController::emitViewportEntered() { - emit selectionChanged(); + emit viewportEntered(); } #include "dolphincontroller.moc"