8ccd1a0d9c
* coding style fixes svn path=/trunk/KDE/kdelibs/; revision=1069730
170 lines
4.3 KiB
C++
170 lines
4.3 KiB
C++
/*
|
|
Copyright (C) 2009 Igor Trindade Oliveira <igor.oliveira@indt.org.br>
|
|
Copyright (C) 2009 Adenilson Cavalcanti <adenilson.silva@idnt.org.br>
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
This library 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
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
#include "rotation_p.h"
|
|
|
|
#include <QGraphicsRotation>
|
|
#include <QEasingCurve>
|
|
|
|
#include <kdebug.h>
|
|
|
|
namespace Plasma
|
|
{
|
|
|
|
RotationAnimation::RotationAnimation(QObject *parent,
|
|
const qint8 &reference,
|
|
const Qt::Axis &axis,
|
|
const qreal &angle)
|
|
: Animation(parent)
|
|
{
|
|
setAngle(angle);
|
|
setAxis(axis);
|
|
setReference(reference);
|
|
|
|
m_rotation = new QGraphicsRotation(this);
|
|
}
|
|
|
|
RotationAnimation::~RotationAnimation()
|
|
{
|
|
}
|
|
|
|
Qt::Axis RotationAnimation::axis() const
|
|
{
|
|
return m_axis;
|
|
}
|
|
|
|
void RotationAnimation::setAxis(const Qt::Axis &axis)
|
|
{
|
|
m_axis = axis;
|
|
}
|
|
|
|
qint8 RotationAnimation::reference() const
|
|
{
|
|
return m_reference;
|
|
}
|
|
|
|
void RotationAnimation::setReference(const qint8 &reference)
|
|
{
|
|
m_reference = reference;
|
|
}
|
|
|
|
qreal RotationAnimation::angle() const
|
|
{
|
|
return m_angle;
|
|
}
|
|
|
|
void RotationAnimation::setAngle(const qreal &angle)
|
|
{
|
|
m_angle = angle;
|
|
}
|
|
|
|
void RotationAnimation::updateState(QAbstractAnimation::State newState, QAbstractAnimation::State oldState)
|
|
{
|
|
QGraphicsWidget *m_object = targetWidget();
|
|
|
|
if (!m_object) {
|
|
return;
|
|
}
|
|
|
|
QVector3D vector(0, 0, 0);
|
|
|
|
const qreal widgetWidth = m_object->size().width();
|
|
const qreal widgetHeight = m_object->size().height();
|
|
|
|
if (axis() == Qt::XAxis) {
|
|
switch (reference()) {
|
|
case Center:
|
|
vector.setY(widgetHeight/2);
|
|
break;
|
|
case Up:
|
|
vector.setY(0);
|
|
break;
|
|
case Down:
|
|
vector.setY(widgetHeight);
|
|
break;
|
|
}
|
|
|
|
} else if(axis() == Qt::YAxis) {
|
|
switch (reference()) {
|
|
case Center:
|
|
vector.setX(widgetWidth/2);
|
|
break;
|
|
case Left:
|
|
vector.setX(0);
|
|
break;
|
|
case Right:
|
|
vector.setX(widgetWidth);
|
|
break;
|
|
}
|
|
|
|
} else if (axis() == Qt::ZAxis) {
|
|
switch (reference()) {
|
|
case Center:
|
|
vector.setX(widgetWidth/2);
|
|
vector.setY(widgetHeight/2);
|
|
break;
|
|
|
|
case Center|Up:
|
|
vector.setX(widgetWidth/2);
|
|
vector.setY(0);
|
|
break;
|
|
|
|
case Center|Down:
|
|
vector.setX(widgetWidth/2);
|
|
vector.setY(widgetHeight);
|
|
break;
|
|
|
|
case Center|Left:
|
|
vector.setX(0);
|
|
vector.setY(widgetHeight/2);
|
|
break;
|
|
|
|
case Center|Right:
|
|
vector.setX(widgetWidth);
|
|
vector.setY(widgetHeight/2);
|
|
break;
|
|
}
|
|
}
|
|
|
|
m_rotation->setOrigin(vector);
|
|
m_rotation->setAxis(axis());
|
|
|
|
QList<QGraphicsTransform *> transformation;
|
|
transformation.append(m_rotation);
|
|
m_object->setTransformations(transformation);
|
|
|
|
if ((oldState == Stopped) && (newState == Running)) {
|
|
m_rotation->setAngle(direction() == Forward ? 0 : angle());
|
|
} else if (newState == Stopped) {
|
|
m_rotation->setAngle(direction() == Forward ? angle() : 0);
|
|
}
|
|
}
|
|
|
|
void RotationAnimation::updateCurrentTime(int currentTime)
|
|
{
|
|
QGraphicsWidget *w = targetWidget();
|
|
if (w) {
|
|
qreal delta = Animation::easingCurve().valueForProgress(
|
|
currentTime / qreal(duration()));
|
|
delta = angle() * delta;
|
|
m_rotation->setAngle(delta);
|
|
}
|
|
}
|
|
|
|
}
|