Icons now fade in the background animation. They also learnt to react on color theme
changes. Some codingstyle changes as the icing on the cake. The fade-in effect can be switched off with Rafaels new feature, btw. RB:195 svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=779804
This commit is contained in:
parent
758f9ecb0b
commit
ae0510db05
@ -65,9 +65,8 @@ Icon::Private::Private()
|
|||||||
invertLayout(false),
|
invertLayout(false),
|
||||||
drawBg(false)
|
drawBg(false)
|
||||||
{
|
{
|
||||||
//FIXME: update with Theme::change()!
|
m_hoverAnimId = -1;
|
||||||
textColor = Plasma::Theme::self()->textColor();
|
m_hoverAlpha = 20/255;
|
||||||
shadowColor = Plasma::Theme::self()->backgroundColor();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Icon::Private::~Private()
|
Icon::Private::~Private()
|
||||||
@ -76,6 +75,13 @@ Icon::Private::~Private()
|
|||||||
delete iconSvg;
|
delete iconSvg;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Icon::readColors()
|
||||||
|
{
|
||||||
|
d->textColor = Plasma::Theme::self()->textColor();
|
||||||
|
d->shadowColor = Plasma::Theme::self()->backgroundColor();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
IconAction::IconAction(Icon* icon, QAction *action)
|
IconAction::IconAction(Icon* icon, QAction *action)
|
||||||
: m_icon(icon),
|
: m_icon(icon),
|
||||||
m_action(action),
|
m_action(action),
|
||||||
@ -279,6 +285,9 @@ Icon::~Icon()
|
|||||||
|
|
||||||
void Icon::init()
|
void Icon::init()
|
||||||
{
|
{
|
||||||
|
readColors();
|
||||||
|
connect(Plasma::Theme::self(), SIGNAL(changed()), SLOT(readColors()));
|
||||||
|
|
||||||
// setAcceptedMouseButtons(Qt::LeftButton);
|
// setAcceptedMouseButtons(Qt::LeftButton);
|
||||||
setAcceptsHoverEvents(true);
|
setAcceptsHoverEvents(true);
|
||||||
|
|
||||||
@ -297,6 +306,7 @@ void Icon::init()
|
|||||||
|
|
||||||
d->setActiveMargins();
|
d->setActiveMargins();
|
||||||
d->currentSize = QSizeF(-1, -1);
|
d->currentSize = QSizeF(-1, -1);
|
||||||
|
//setDrawStandardBackground(false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Icon::addAction(QAction *action)
|
void Icon::addAction(QAction *action)
|
||||||
@ -336,8 +346,7 @@ void Icon::setNumDisplayLines(int numLines)
|
|||||||
{
|
{
|
||||||
if(numLines > d->maxDisplayLines) {
|
if(numLines > d->maxDisplayLines) {
|
||||||
d->numDisplayLines = d->maxDisplayLines;
|
d->numDisplayLines = d->maxDisplayLines;
|
||||||
}
|
} else {
|
||||||
else {
|
|
||||||
d->numDisplayLines = numLines;
|
d->numDisplayLines = numLines;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -487,6 +496,38 @@ void Icon::setSvg(const QString &svgFilePath, const QString &elementId)
|
|||||||
d->iconSvgElement = elementId;
|
d->iconSvgElement = elementId;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Icon::hoverEffect(bool show)
|
||||||
|
{
|
||||||
|
d->m_fadeIn = show;
|
||||||
|
const int FadeInDuration = 150;
|
||||||
|
|
||||||
|
if (d->m_hoverAnimId != -1) {
|
||||||
|
Phase::self()->stopCustomAnimation(d->m_hoverAnimId);
|
||||||
|
}
|
||||||
|
d->m_hoverAnimId = Phase::self()->customAnimation(40 / (1000 / FadeInDuration), FadeInDuration,
|
||||||
|
Phase::EaseOutCurve, this,
|
||||||
|
"hoverAnimationUpdate");
|
||||||
|
}
|
||||||
|
|
||||||
|
void Icon::hoverAnimationUpdate(qreal progress)
|
||||||
|
{
|
||||||
|
if (d->m_fadeIn) {
|
||||||
|
d->m_hoverAlpha = progress;
|
||||||
|
} else {
|
||||||
|
// If we mouse leaves before the fade in is done, fade out from where we were,
|
||||||
|
// not from fully faded in
|
||||||
|
qreal new_alpha = d->m_fadeIn ? progress : 1 - progress;
|
||||||
|
d->m_hoverAlpha = qMin(new_alpha, d->m_hoverAlpha);
|
||||||
|
}
|
||||||
|
if (progress == 1) {
|
||||||
|
d->m_hoverAnimId = -1;
|
||||||
|
}
|
||||||
|
if (!d->m_fadeIn && progress == 1 ) {
|
||||||
|
d->states &= ~Private::HoverState;
|
||||||
|
}
|
||||||
|
update();
|
||||||
|
}
|
||||||
|
|
||||||
void Icon::Private::drawBackground(QPainter *painter, IconState state)
|
void Icon::Private::drawBackground(QPainter *painter, IconState state)
|
||||||
{
|
{
|
||||||
if (!drawBg) {
|
if (!drawBg) {
|
||||||
@ -497,32 +538,32 @@ void Icon::Private::drawBackground(QPainter *painter, IconState state)
|
|||||||
QColor shadow = shadowColor;
|
QColor shadow = shadowColor;
|
||||||
QColor border = textColor;
|
QColor border = textColor;
|
||||||
|
|
||||||
shadow.setAlphaF(.60);
|
|
||||||
border.setAlphaF(.20);
|
border.setAlphaF(.20);
|
||||||
|
|
||||||
switch (state) {
|
switch (state) {
|
||||||
case Private::HoverState:
|
case Private::HoverState:
|
||||||
shadow.setHsv(shadow.hue(),
|
shadow.setHsv(shadow.hue(),
|
||||||
shadow.saturation(),
|
shadow.saturation(),
|
||||||
shadow.value() + (darkShadow?50:-50),
|
shadow.value() + (int)(darkShadow?50*m_hoverAlpha:-50*m_hoverAlpha),
|
||||||
180); //70% opacity
|
200+(int)m_hoverAlpha*55); // opacity
|
||||||
break;
|
break;
|
||||||
case Private::PressedState:
|
case Private::PressedState:
|
||||||
shadow.setHsv(shadow.hue(),
|
shadow.setHsv(shadow.hue(),
|
||||||
shadow.saturation(),
|
shadow.saturation(),
|
||||||
shadow.value() + (darkShadow?100:-100),
|
shadow.value() + (darkShadow?(int)(50*m_hoverAlpha):(int)(-50*m_hoverAlpha)),
|
||||||
204); //80% opacity
|
204); //80% opacity
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
painter->save();
|
painter->save();
|
||||||
painter->translate(0.5, 0.5);
|
painter->translate(0.5, 0.5);
|
||||||
painter->setRenderHint(QPainter::Antialiasing);
|
painter->setRenderHint(QPainter::Antialiasing);
|
||||||
|
shadow.setAlphaF(.6);
|
||||||
painter->setBrush(shadow);
|
painter->setBrush(shadow);
|
||||||
painter->setPen(QPen(border, 1));
|
painter->setPen(QPen(border, 1));
|
||||||
painter->drawPath(roundedRectangle(QRectF(QPointF(1, 1), QSize(currentSize.width()-2, currentSize.height()-2)), 5.0));
|
painter->drawPath(roundedRectangle(QRectF(QPointF(1, 1), QSize((int)currentSize.width()-2, (int)currentSize.height()-2)), 5.0));
|
||||||
painter->restore();
|
painter->restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -550,12 +591,13 @@ QPixmap Icon::Private::decoration(const QStyleOptionGraphicsItem *option, bool u
|
|||||||
result = icon.pixmap(size, mode, state);
|
result = icon.pixmap(size, mode, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!result.isNull() && useHoverEffect) {
|
// We disable the iconeffect here since we cannot get it into sync with
|
||||||
|
// the fade animation. TODO: Enable it when animations are switched off
|
||||||
|
if (!result.isNull() && useHoverEffect && !drawBg) {
|
||||||
KIconEffect *effect = KIconLoader::global()->iconEffect();
|
KIconEffect *effect = KIconLoader::global()->iconEffect();
|
||||||
|
|
||||||
// Note that in KIconLoader terminology, active = hover.
|
// Note that in KIconLoader terminology, active = hover.
|
||||||
// ### We're assuming that the icon group is desktop/filemanager, since this
|
// We're assuming that the icon group is desktop/filemanager, since this
|
||||||
// is KFileItemDelegate.
|
// is KFileItemDelegate.
|
||||||
if (effect->hasEffect(KIconLoader::Desktop, KIconLoader::ActiveState)) {
|
if (effect->hasEffect(KIconLoader::Desktop, KIconLoader::ActiveState)) {
|
||||||
result = effect->apply(result, KIconLoader::Desktop, KIconLoader::ActiveState);
|
result = effect->apply(result, KIconLoader::Desktop, KIconLoader::ActiveState);
|
||||||
}
|
}
|
||||||
@ -745,11 +787,11 @@ void Icon::Private::layoutTextItems(const QStyleOptionGraphicsItem *option,
|
|||||||
maxInfoSize.rheight() -= labelSize.height();
|
maxInfoSize.rheight() -= labelSize.height();
|
||||||
|
|
||||||
// Lay out the info text
|
// Lay out the info text
|
||||||
if (showInformation)
|
if (showInformation) {
|
||||||
infoSize = layoutText(*infoLayout, option, infoText, maxInfoSize);
|
infoSize = layoutText(*infoLayout, option, infoText, maxInfoSize);
|
||||||
else
|
} else {
|
||||||
infoSize = QSizeF(0, 0);
|
infoSize = QSizeF(0, 0);
|
||||||
|
}
|
||||||
// Compute the bounding rect of the text
|
// Compute the bounding rect of the text
|
||||||
const Qt::Alignment alignment = labelLayout->textOption().alignment();
|
const Qt::Alignment alignment = labelLayout->textOption().alignment();
|
||||||
const QSizeF size(qMax(labelSize.width(), infoSize.width()), labelSize.height() + infoSize.height());
|
const QSizeF size(qMax(labelSize.width(), infoSize.width()), labelSize.height() + infoSize.height());
|
||||||
@ -766,9 +808,9 @@ QBrush Icon::Private::foregroundBrush(const QStyleOptionGraphicsItem *option) co
|
|||||||
QPalette::Normal : QPalette::Disabled;
|
QPalette::Normal : QPalette::Disabled;
|
||||||
|
|
||||||
// Always use the highlight color for selected items
|
// Always use the highlight color for selected items
|
||||||
if (option->state & QStyle::State_Selected)
|
if (option->state & QStyle::State_Selected) {
|
||||||
return option->palette.brush(group, QPalette::HighlightedText);
|
return option->palette.brush(group, QPalette::HighlightedText);
|
||||||
|
}
|
||||||
return option->palette.brush(group, QPalette::Text);
|
return option->palette.brush(group, QPalette::Text);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -780,9 +822,9 @@ QBrush Icon::Private::backgroundBrush(const QStyleOptionGraphicsItem *option) co
|
|||||||
QBrush background(Qt::NoBrush);
|
QBrush background(Qt::NoBrush);
|
||||||
|
|
||||||
// Always use the highlight color for selected items
|
// Always use the highlight color for selected items
|
||||||
if (option->state & QStyle::State_Selected)
|
if (option->state & QStyle::State_Selected) {
|
||||||
background = option->palette.brush(group, QPalette::Highlight);
|
background = option->palette.brush(group, QPalette::Highlight);
|
||||||
|
}
|
||||||
return background;
|
return background;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1037,8 +1079,8 @@ void Icon::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
|
|||||||
action->show();
|
action->show();
|
||||||
action->event(event->type(), event->pos());
|
action->event(event->type(), event->pos());
|
||||||
}
|
}
|
||||||
|
|
||||||
d->states |= Private::HoverState;
|
d->states |= Private::HoverState;
|
||||||
|
hoverEffect(true);
|
||||||
update();
|
update();
|
||||||
|
|
||||||
Widget::hoverEnterEvent(event);
|
Widget::hoverEnterEvent(event);
|
||||||
@ -1050,8 +1092,8 @@ void Icon::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
|
|||||||
action->hide();
|
action->hide();
|
||||||
action->event(event->type(), event->pos());
|
action->event(event->type(), event->pos());
|
||||||
}
|
}
|
||||||
|
// d->states &= ~Private::HoverState; // Will be set once progress is zero again ...
|
||||||
d->states &= ~Private::HoverState;
|
hoverEffect(false);
|
||||||
update();
|
update();
|
||||||
|
|
||||||
Widget::hoverLeaveEvent(event);
|
Widget::hoverLeaveEvent(event);
|
||||||
|
@ -255,11 +255,15 @@ public:
|
|||||||
private:
|
private:
|
||||||
void init();
|
void init();
|
||||||
void layoutIcons(const QStyleOptionGraphicsItem *option);
|
void layoutIcons(const QStyleOptionGraphicsItem *option);
|
||||||
|
void hoverEffect(bool);
|
||||||
|
|
||||||
Private * const d;
|
Private * const d;
|
||||||
|
|
||||||
private Q_SLOTS:
|
private Q_SLOTS:
|
||||||
void actionDestroyed(QObject* obj);
|
void actionDestroyed(QObject* obj);
|
||||||
|
void readColors();
|
||||||
|
void hoverAnimationUpdate(qreal progress);
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace Plasma
|
} // namespace Plasma
|
||||||
|
@ -33,6 +33,7 @@
|
|||||||
#include <plasma/svg.h>
|
#include <plasma/svg.h>
|
||||||
|
|
||||||
#include "icon.h"
|
#include "icon.h"
|
||||||
|
#include "phase.h"
|
||||||
|
|
||||||
class QAction;
|
class QAction;
|
||||||
class QPainter;
|
class QPainter;
|
||||||
@ -128,6 +129,7 @@ public:
|
|||||||
void layoutTextItems(const QStyleOptionGraphicsItem *option, const QPixmap &icon,
|
void layoutTextItems(const QStyleOptionGraphicsItem *option, const QPixmap &icon,
|
||||||
QTextLayout *labelLayout, QTextLayout *infoLayout, QRectF *textBoundingRect) const;
|
QTextLayout *labelLayout, QTextLayout *infoLayout, QRectF *textBoundingRect) const;
|
||||||
|
|
||||||
|
|
||||||
inline void setLayoutOptions(QTextLayout &layout, const QStyleOptionGraphicsItem *options) const;
|
inline void setLayoutOptions(QTextLayout &layout, const QStyleOptionGraphicsItem *options) const;
|
||||||
|
|
||||||
inline Qt::LayoutDirection iconDirection(const QStyleOptionGraphicsItem *option) const;
|
inline Qt::LayoutDirection iconDirection(const QStyleOptionGraphicsItem *option) const;
|
||||||
@ -168,6 +170,9 @@ public:
|
|||||||
QPixmap iconSvgPixmap;
|
QPixmap iconSvgPixmap;
|
||||||
QColor textColor;
|
QColor textColor;
|
||||||
QColor shadowColor;
|
QColor shadowColor;
|
||||||
|
bool m_fadeIn;
|
||||||
|
Phase::AnimId m_hoverAnimId;
|
||||||
|
qreal m_hoverAlpha;
|
||||||
QSizeF iconSize;
|
QSizeF iconSize;
|
||||||
QIcon icon;
|
QIcon icon;
|
||||||
IconStates states;
|
IconStates states;
|
||||||
@ -213,7 +218,7 @@ Qt::LayoutDirection Icon::Private::iconDirection(const QStyleOptionGraphicsItem
|
|||||||
}else{
|
}else{
|
||||||
direction = Qt::LeftToRight;
|
direction = Qt::LeftToRight;
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
direction = option->direction;
|
direction = option->direction;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user