combobox uses PaintUtils::transition

some cleanups in PushButton

svn path=/trunk/KDE/kdebase/workspace/libs/plasma/; revision=867098
This commit is contained in:
Marco Martin 2008-10-02 19:39:00 +00:00
parent 165f387e45
commit 1f7a0f7560
3 changed files with 39 additions and 58 deletions

View File

@ -30,6 +30,7 @@
#include "theme.h"
#include "panelsvg.h"
#include "animator.h"
#include "paintutils.h"
namespace Plasma
{
@ -39,8 +40,7 @@ class ComboBoxPrivate
public:
ComboBoxPrivate(ComboBox *comboBox)
: q(comboBox),
background(0),
activeBackgroundPixmap(0)
background(0)
{
}
@ -48,29 +48,19 @@ public:
{
}
void renderActiveBackgroundPixmap();
void syncActiveRect();
void syncBorders();
void elementAnimationFinished(int id);
void animationUpdate(qreal progress);
ComboBox *q;
PanelSvg *background;
QPixmap *activeBackgroundPixmap;
int animId;
bool fadeIn;
qreal opacity;
QRectF activeRect;
};
void ComboBoxPrivate::renderActiveBackgroundPixmap()
{
background->setElementPrefix("active");
activeBackgroundPixmap = new QPixmap(activeRect.size().toSize());
activeBackgroundPixmap->fill(Qt::transparent);
QPainter painter(activeBackgroundPixmap);
background->paintPanel(&painter);
}
void ComboBoxPrivate::syncActiveRect()
{
@ -102,14 +92,21 @@ void ComboBoxPrivate::syncBorders()
syncActiveRect();
}
void ComboBoxPrivate::elementAnimationFinished(int id)
void ComboBoxPrivate::animationUpdate(qreal progress)
{
if (id == animId) {
if (progress == 1) {
animId = -1;
fadeIn = true;
}
opacity = fadeIn ? progress : 1 - progress;
// explicit update
q->update();
}
ComboBox::ComboBox(QGraphicsWidget *parent)
: QGraphicsProxyWidget(parent),
d(new ComboBoxPrivate(this))
@ -126,7 +123,6 @@ ComboBox::ComboBox(QGraphicsWidget *parent)
d->syncBorders();
setAcceptHoverEvents(true);
connect(Plasma::Animator::self(), SIGNAL(elementAnimationFinished(int)), this, SLOT(elementAnimationFinished(int)));
connect(Plasma::Theme::defaultTheme(), SIGNAL(themeChanged()), SLOT(syncBorders()));
}
@ -179,11 +175,6 @@ void ComboBox::resizeEvent(QGraphicsSceneResizeEvent *event)
d->background->setElementPrefix("normal");
d->background->resizePanel(size());
if (d->activeBackgroundPixmap) {
delete d->activeBackgroundPixmap;
d->activeBackgroundPixmap = 0;
}
}
QGraphicsProxyWidget::resizeEvent(event);
@ -200,12 +191,15 @@ void ComboBox::paint(QPainter *painter,
QPixmap bufferPixmap;
//Normal button, pressed or not
//normal button
if (isEnabled()) {
d->background->setElementPrefix("normal");
d->background->paintPanel(painter);
//flat or disabled
} else if (!isEnabled()) {
if (d->animId == -1) {
d->background->paintPanel(painter);
}
//disabled widget
} else {
bufferPixmap = QPixmap(rect().size().toSize());
bufferPixmap.fill(Qt::transparent);
@ -220,12 +214,13 @@ void ComboBox::paint(QPainter *painter,
//if is under mouse draw the animated glow overlay
if (isEnabled() && acceptHoverEvents()) {
if (d->animId != -1) {
painter->drawPixmap(d->activeRect.topLeft(), Plasma::Animator::self()->currentPixmap(d->animId) );
d->background->setElementPrefix("normal");
QPixmap normalPix = d->background->panelPixmap();
d->background->setElementPrefix("active");
painter->drawPixmap(d->activeRect.topLeft(), PaintUtils::transition(d->background->panelPixmap(), normalPix, 1 - d->opacity));
} else if (isUnderMouse()) {
if (d->activeBackgroundPixmap == 0) {
d->renderActiveBackgroundPixmap();
}
painter->drawPixmap( d->activeRect.topLeft(), *d->activeBackgroundPixmap );
d->background->setElementPrefix("active");
d->background->paintPanel(painter, d->activeRect.topLeft());
}
}
@ -253,35 +248,31 @@ void ComboBox::paint(QPainter *painter,
void ComboBox::hoverEnterEvent(QGraphicsSceneHoverEvent *event)
{
const int FadeInDuration = 75;
if (d->animId != -1) {
Plasma::Animator::self()->stopElementAnimation(d->animId);
Plasma::Animator::self()->stopCustomAnimation(d->animId);
}
d->animId = Plasma::Animator::self()->animateElement(this, Plasma::Animator::AppearAnimation);
d->animId = Plasma::Animator::self()->customAnimation(40 / (1000 / FadeInDuration), FadeInDuration,Plasma::Animator::LinearCurve, this, "animationUpdate");
d->background->setElementPrefix("active");
if (!d->activeBackgroundPixmap) {
d->renderActiveBackgroundPixmap();
}
Plasma::Animator::self()->setInitialPixmap( d->animId, *d->activeBackgroundPixmap );
QGraphicsProxyWidget::hoverEnterEvent(event);
}
void ComboBox::hoverLeaveEvent(QGraphicsSceneHoverEvent *event)
{
const int FadeOutDuration = 150;
if (d->animId != -1) {
Plasma::Animator::self()->stopElementAnimation(d->animId);
Plasma::Animator::self()->stopCustomAnimation(d->animId != -1);
}
d->animId = Plasma::Animator::self()->animateElement(this, Plasma::Animator::DisappearAnimation);
d->fadeIn = false;
d->animId = Plasma::Animator::self()->customAnimation(40 / (1000 / FadeOutDuration), FadeOutDuration,Plasma::Animator::LinearCurve, this, "animationUpdate");
d->background->setElementPrefix("active");
if (!d->activeBackgroundPixmap) {
d->renderActiveBackgroundPixmap();
}
Plasma::Animator::self()->setInitialPixmap( d->animId, *d->activeBackgroundPixmap );
QGraphicsProxyWidget::hoverLeaveEvent(event);
}

View File

@ -97,7 +97,7 @@ private:
friend class ComboBoxPrivate;
Q_PRIVATE_SLOT(d, void syncBorders())
Q_PRIVATE_SLOT(d, void elementAnimationFinished(int id))
Q_PRIVATE_SLOT(d, void animationUpdate(qreal progress))
};
} // namespace Plasma

View File

@ -45,7 +45,6 @@ public:
PushButtonPrivate(PushButton *pushButton)
: q(pushButton),
background(0),
activeBackgroundPixmap(0),
animId(-1),
fadeIn(false),
svg(0)
@ -84,8 +83,6 @@ public:
PushButton *q;
PanelSvg *background;
QPixmap *activeBackgroundPixmap;
QPixmap *backgroundPixmap;
int animId;
bool fadeIn;
qreal opacity;
@ -229,8 +226,6 @@ void PushButton::resizeEvent(QGraphicsSceneResizeEvent *event)
if (d->background) {
//resize all four panels
d->background->setElementPrefix("normal");
d->background->resizePanel(size());
d->background->setElementPrefix("pressed");
d->background->resizePanel(size());
d->background->setElementPrefix("focus");
@ -242,11 +237,7 @@ void PushButton::resizeEvent(QGraphicsSceneResizeEvent *event)
d->background->resizePanel(d->activeRect.size());
d->background->setElementPrefix("normal");
if (d->activeBackgroundPixmap) {
delete d->activeBackgroundPixmap;
d->activeBackgroundPixmap = 0;
}
d->background->resizePanel(size());
}
QGraphicsProxyWidget::resizeEvent(event);
@ -289,7 +280,6 @@ void PushButton::paint(QPainter *painter,
//if is under mouse draw the animated glow overlay
if (!nativeWidget()->isDown() && isEnabled() && acceptHoverEvents()) {
if (d->animId != -1) {
//QPixmap normalPix = QPixmap(d->activeRect.size());
QPixmap normalPix = d->background->panelPixmap();
d->background->setElementPrefix("active");
painter->drawPixmap(d->activeRect.topLeft(), PaintUtils::transition(d->background->panelPixmap(), normalPix, 1 - d->opacity));