2009-12-05 20:54:27 +01:00
|
|
|
/*
|
|
|
|
* Copyright 2009 Igor Trindade Oliveira <igor.oliveira@indt.org.br>
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Library General Public License as
|
|
|
|
* published by the Free Software Foundation; either version 2, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this program; if not, write to the
|
|
|
|
* Free Software Foundation, Inc.,
|
|
|
|
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
#include "geometry_p.h"
|
2009-12-05 20:54:27 +01:00
|
|
|
|
|
|
|
#include <QRect>
|
|
|
|
|
|
|
|
#include <kdebug.h>
|
|
|
|
|
|
|
|
namespace Plasma
|
|
|
|
{
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
GeometryAnimation::GeometryAnimation(QObject *parent)
|
2010-04-08 19:07:33 +02:00
|
|
|
: EasingAnimation(parent),
|
2009-12-05 20:54:27 +01:00
|
|
|
m_startGeometry(-1, -1, -1, -1)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
GeometryAnimation::~GeometryAnimation()
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
void GeometryAnimation::setStartGeometry(const QRectF &geometry)
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
|
|
|
m_startGeometry = geometry;
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
QRectF GeometryAnimation::startGeometry() const
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
|
|
|
return m_startGeometry;
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
void GeometryAnimation::setTargetGeometry(const QRectF &geometry)
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
|
|
|
m_targetGeometry = geometry;
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
QRectF GeometryAnimation::targetGeometry() const
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
|
|
|
return m_targetGeometry;
|
|
|
|
}
|
|
|
|
|
2009-12-08 10:22:51 +01:00
|
|
|
void GeometryAnimation::updateState(QAbstractAnimation::State newState, QAbstractAnimation::State oldState)
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
2010-01-04 10:18:11 +01:00
|
|
|
QGraphicsWidget *w = targetWidget();
|
2009-12-05 20:54:27 +01:00
|
|
|
if (!w) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m_startGeometry == QRectF(-1, -1, -1, -1)) {
|
|
|
|
m_startGeometry = w->geometry();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (oldState == Stopped && newState == Running) {
|
|
|
|
w->setGeometry(direction() == Forward ? m_startGeometry : m_targetGeometry);
|
|
|
|
} else if (newState == Stopped) {
|
|
|
|
w->setGeometry(direction() == Forward ? m_targetGeometry : m_startGeometry);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2010-04-08 19:07:33 +02:00
|
|
|
void GeometryAnimation::updateEffectiveTime(int currentTime)
|
2009-12-05 20:54:27 +01:00
|
|
|
{
|
2010-01-04 10:18:11 +01:00
|
|
|
QGraphicsWidget *w = targetWidget();
|
2009-12-05 20:54:27 +01:00
|
|
|
if (w) {
|
2009-12-09 17:34:43 +01:00
|
|
|
qreal delta = Animation::easingCurve().valueForProgress(
|
|
|
|
currentTime / qreal(duration()));
|
2009-12-05 20:54:27 +01:00
|
|
|
|
|
|
|
QRectF newGeo = m_startGeometry;
|
|
|
|
newGeo.adjust((-m_startGeometry.x() + m_targetGeometry.x()) * delta,
|
|
|
|
(-m_startGeometry.y() + m_targetGeometry.y()) * delta,
|
|
|
|
(-m_startGeometry.width() + m_targetGeometry.width()) * delta,
|
|
|
|
(-m_startGeometry.height() + m_targetGeometry.height()) * delta);
|
|
|
|
|
|
|
|
w->setGeometry(newGeo);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
} //namespace Plasma
|
2010-02-24 00:31:45 +01:00
|
|
|
|
|
|
|
#include <../geometry_p.moc>
|