X-Git-Url: https://cloud.milkyroute.net/gitweb/dolphin.git/blobdiff_plain/846b21edf57e7aeb83e84ee68e9f61c5981fbacd..9a8f75e93cbddca787cbfea8d27ed60009a44512:/src/selectiontoggle.cpp diff --git a/src/selectiontoggle.cpp b/src/selectiontoggle.cpp index 7a3f0ef56..eb02edcb2 100644 --- a/src/selectiontoggle.cpp +++ b/src/selectiontoggle.cpp @@ -38,9 +38,9 @@ SelectionToggle::SelectionToggle(QWidget* parent) : { parent->installEventFilter(this); resize(sizeHint()); - m_icon = KIconLoader::global()->loadIcon("dialog-ok", - KIconLoader::NoGroup, - KIconLoader::SizeSmall); + setIconOverlay(isChecked()); + connect(this, SIGNAL(toggled(bool)), + this, SLOT(setIconOverlay(bool))); } SelectionToggle::~SelectionToggle() @@ -54,21 +54,21 @@ QSize SelectionToggle::sizeHint() const void SelectionToggle::reset() { - m_item = KFileItem(); + m_url = KUrl(); hide(); } -void SelectionToggle::setFileItem(const KFileItem& item) +void SelectionToggle::setUrl(const KUrl& url) { - m_item = item; - if (!item.isNull()) { + m_url = url; + if (!url.isEmpty()) { startFading(); } } -KFileItem SelectionToggle::fileItem() const +KUrl SelectionToggle::url() const { - return m_item; + return m_url; } void SelectionToggle::setVisible(bool visible) @@ -115,7 +115,24 @@ void SelectionToggle::paintEvent(QPaintEvent* event) { QPainter painter(this); painter.setClipRect(event->rect()); + painter.setRenderHint(QPainter::Antialiasing); + + // draw an alpha blended circle as background + const QPalette& palette = parentWidget()->palette(); + + const QBrush& backgroundBrush = palette.brush(QPalette::Normal, QPalette::Window); + QColor background = backgroundBrush.color(); + background.setAlpha(m_fadingValue / 2); + painter.setBrush(background); + + const QBrush& foregroundBrush = palette.brush(QPalette::Normal, QPalette::WindowText); + QColor foreground = foregroundBrush.color(); + foreground.setAlpha(m_fadingValue / 4); + painter.setPen(foreground); + + painter.drawEllipse(0, 0, width(), height()); + // draw the icon overlay if (m_isHovered) { KIconEffect iconEffect; QPixmap activeIcon = iconEffect.apply(m_icon, KIconLoader::Desktop, KIconLoader::ActiveState); @@ -146,11 +163,20 @@ void SelectionToggle::setFadingValue(int value) update(); } +void SelectionToggle::setIconOverlay(bool checked) +{ + const char* icon = checked ? "list-remove" : "list-add"; + m_icon = KIconLoader::global()->loadIcon(icon, + KIconLoader::NoGroup, + KIconLoader::SizeSmall); + update(); +} + void SelectionToggle::startFading() { Q_ASSERT(m_fadingTimeLine == 0); - m_fadingTimeLine = new QTimeLine(2000, this); + m_fadingTimeLine = new QTimeLine(1500, this); connect(m_fadingTimeLine, SIGNAL(frameChanged(int)), this, SLOT(setFadingValue(int))); m_fadingTimeLine->setFrameRange(0, 255);