X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/afb9e2d1323f269bd410265c08212643c612a3b3..87cd992e85effd14938f67c0671ef2e7cb93a8a7:/src/selectiontoggle.cpp diff --git a/src/selectiontoggle.cpp b/src/selectiontoggle.cpp index 14ec04840..6608b5821 100644 --- a/src/selectiontoggle.cpp +++ b/src/selectiontoggle.cpp @@ -34,6 +34,7 @@ SelectionToggle::SelectionToggle(QWidget* parent) : QAbstractButton(parent), m_isHovered(false), + m_leftMouseButtonPressed(false), m_fadingValue(0), m_icon(), m_fadingTimeLine(0) @@ -44,6 +45,8 @@ SelectionToggle::SelectionToggle(QWidget* parent) : setIconOverlay(isChecked()); connect(this, SIGNAL(toggled(bool)), this, SLOT(setIconOverlay(bool))); + connect(KGlobalSettings::self(), SIGNAL(iconChanged(int)), + this, SLOT(refreshIcon())); } SelectionToggle::~SelectionToggle() @@ -87,9 +90,27 @@ void SelectionToggle::setVisible(bool visible) bool SelectionToggle::eventFilter(QObject* obj, QEvent* event) { - if ((obj == parent()) && (event->type() == QEvent::Leave)) { - hide(); + if (obj == parent()) { + switch (event->type()) { + case QEvent::Leave: + hide(); + break; + + case QEvent::MouseMove: + if (m_leftMouseButtonPressed) { + // Don't forward mouse move events to the viewport, + // otherwise a rubberband selection will be shown when + // clicking on the selection toggle and moving the mouse + // above the viewport. + return true; + } + break; + + default: + break; + } } + return QAbstractButton::eventFilter(obj, event); } @@ -116,26 +137,28 @@ void SelectionToggle::leaveEvent(QEvent* event) update(); } -void SelectionToggle::paintEvent(QPaintEvent* event) +void SelectionToggle::mousePressEvent(QMouseEvent* event) { - QPainter painter(this); - painter.setClipRect(event->rect()); - painter.setRenderHint(QPainter::Antialiasing); - - // draw an alpha blended circle as background - const QPalette& palette = parentWidget()->palette(); + QAbstractButton::mousePressEvent(event); + m_leftMouseButtonPressed = (event->buttons() & Qt::LeftButton); +} - const QBrush& backgroundBrush = palette.brush(QPalette::Normal, QPalette::Window); - QColor background = backgroundBrush.color(); - background.setAlpha(m_fadingValue / 2); - painter.setBrush(background); +void SelectionToggle::mouseReleaseEvent(QMouseEvent* event) +{ + QAbstractButton::mouseReleaseEvent(event); + m_leftMouseButtonPressed = (event->buttons() & Qt::LeftButton); +} - const QBrush& foregroundBrush = palette.brush(QPalette::Normal, QPalette::WindowText); - QColor foreground = foregroundBrush.color(); - foreground.setAlpha(m_fadingValue / 4); - painter.setPen(foreground); +void SelectionToggle::resizeEvent(QResizeEvent* event) +{ + QAbstractButton::resizeEvent(event); + setIconOverlay(isChecked()); +} - painter.drawEllipse(0, 0, width(), height()); +void SelectionToggle::paintEvent(QPaintEvent* event) +{ + QPainter painter(this); + painter.setClipRect(event->rect()); // draw the icon overlay if (m_isHovered) { @@ -173,10 +196,15 @@ void SelectionToggle::setIconOverlay(bool checked) const char* icon = checked ? "list-remove" : "list-add"; m_icon = KIconLoader::global()->loadIcon(icon, KIconLoader::NoGroup, - KIconLoader::SizeSmall); + qMin(width(), height())); update(); } +void SelectionToggle::refreshIcon() +{ + setIconOverlay(isChecked()); +} + void SelectionToggle::startFading() { Q_ASSERT(m_fadingTimeLine == 0);