axisanimation.cpp
140 lines
| 4.3 KiB
| text/x-c
|
CppLexer
Jani Honkonen
|
r794 | /**************************************************************************** | ||
** | ||||
** Copyright (C) 2012 Digia Plc | ||||
** All rights reserved. | ||||
** For any questions to Digia, please use contact form at http://qt.digia.com | ||||
** | ||||
** This file is part of the Qt Commercial Charts Add-on. | ||||
** | ||||
** $QT_BEGIN_LICENSE$ | ||||
** Licensees holding valid Qt Commercial licenses may use this file in | ||||
** accordance with the Qt Commercial License Agreement provided with the | ||||
** Software or, alternatively, in accordance with the terms contained in | ||||
** a written agreement between you and Digia. | ||||
** | ||||
** If you have questions regarding the use of this file, please use | ||||
** contact form at http://qt.digia.com | ||||
** $QT_END_LICENSE$ | ||||
** | ||||
****************************************************************************/ | ||||
Michal Klocek
|
r530 | #include "axisanimation_p.h" | ||
Michal Klocek
|
r1241 | #include "chartaxis_p.h" | ||
Michal Klocek
|
r530 | |||
Q_DECLARE_METATYPE(QVector<qreal>) | ||||
QTCOMMERCIALCHART_BEGIN_NAMESPACE | ||||
Jani Honkonen
|
r2097 | AxisAnimation::AxisAnimation(ChartAxis *axis) | ||
: ChartAnimation(axis), | ||||
m_axis(axis), | ||||
m_type(DefaultAnimation) | ||||
Michal Klocek
|
r530 | { | ||
Michal Klocek
|
r1241 | setDuration(ChartAnimationDuration); | ||
setEasingCurve(QEasingCurve::OutQuart); | ||||
Michal Klocek
|
r530 | } | ||
AxisAnimation::~AxisAnimation() | ||||
{ | ||||
} | ||||
Michal Klocek
|
r1241 | void AxisAnimation::setAnimationType(Animation type) | ||
{ | ||||
Jani Honkonen
|
r2097 | if (state() != QAbstractAnimation::Stopped) | ||
stop(); | ||||
m_type = type; | ||||
Michal Klocek
|
r1241 | } | ||
Jani Honkonen
|
r2104 | void AxisAnimation::setAnimationPoint(const QPointF &point) | ||
Michal Klocek
|
r1241 | { | ||
Jani Honkonen
|
r2097 | if (state() != QAbstractAnimation::Stopped) | ||
stop(); | ||||
m_point = point; | ||||
Michal Klocek
|
r1241 | } | ||
void AxisAnimation::setValues(QVector<qreal> &oldLayout, QVector<qreal> &newLayout) | ||||
{ | ||||
Michal Klocek
|
r2105 | if (state() != QAbstractAnimation::Stopped) stop(); | ||
Jani Honkonen
|
r2097 | |||
Michal Klocek
|
r2407 | // TODO: cannot return even if layout is empty | ||
// New layout is not set properly without it (crash) | ||||
// if (newLayout.count() == 0) | ||||
// return; | ||||
Jani Honkonen
|
r2097 | switch (m_type) { | ||
Jani Honkonen
|
r2131 | case ZoomOutAnimation: { | ||
QRectF rect = m_axis->gridGeometry(); | ||||
oldLayout.resize(newLayout.count()); | ||||
Jani Honkonen
|
r2097 | |||
Jani Honkonen
|
r2131 | for (int i = 0, j = oldLayout.count() - 1; i < (oldLayout.count() + 1) / 2; ++i, --j) { | ||
oldLayout[i] = m_axis->orientation() == Qt::Horizontal ? rect.left() : rect.bottom(); | ||||
oldLayout[j] = m_axis->orientation() == Qt::Horizontal ? rect.right() : rect.top(); | ||||
Jani Honkonen
|
r2097 | } | ||
Jani Honkonen
|
r2131 | } | ||
break; | ||||
case ZoomInAnimation: { | ||||
int index = qMin(oldLayout.count() * (m_axis->orientation() == Qt::Horizontal ? m_point.x() : (1 - m_point.y())), newLayout.count() - (qreal)1.0); | ||||
oldLayout.resize(newLayout.count()); | ||||
Jani Honkonen
|
r2097 | |||
Jani Honkonen
|
r2131 | for (int i = 0; i < oldLayout.count(); i++) | ||
oldLayout[i] = oldLayout[index]; | ||||
} | ||||
break; | ||||
case MoveForwardAnimation: { | ||||
oldLayout.resize(newLayout.count()); | ||||
Jani Honkonen
|
r2097 | |||
Jani Honkonen
|
r2131 | for (int i = 0, j = i + 1; i < oldLayout.count() - 1; ++i, ++j) | ||
oldLayout[i] = oldLayout[j]; | ||||
} | ||||
break; | ||||
case MoveBackwordAnimation: { | ||||
oldLayout.resize(newLayout.count()); | ||||
for (int i = oldLayout.count() - 1, j = i - 1; i > 0; --i, --j) | ||||
oldLayout[i] = oldLayout[j]; | ||||
} | ||||
break; | ||||
default: { | ||||
oldLayout.resize(newLayout.count()); | ||||
QRectF rect = m_axis->gridGeometry(); | ||||
for (int i = 0, j = oldLayout.count() - 1; i < oldLayout.count(); ++i, --j) | ||||
Michal Klocek
|
r2111 | oldLayout[i] = m_axis->orientation() == Qt::Horizontal ? rect.left() : rect.top(); | ||
Jani Honkonen
|
r2131 | } | ||
break; | ||||
Jani Honkonen
|
r2097 | } | ||
QVariantAnimation::KeyValues value; | ||||
setKeyValues(value); //workaround for wrong interpolation call | ||||
setKeyValueAt(0.0, qVariantFromValue(oldLayout)); | ||||
setKeyValueAt(1.0, qVariantFromValue(newLayout)); | ||||
Michal Klocek
|
r1241 | } | ||
Jani Honkonen
|
r2097 | QVariant AxisAnimation::interpolated(const QVariant &start, const QVariant &end, qreal progress) const | ||
Michal Klocek
|
r530 | { | ||
Jani Honkonen
|
r2241 | QVector<qreal> startVector = qvariant_cast<QVector<qreal> >(start); | ||
QVector<qreal> endVecotr = qvariant_cast<QVector<qreal> >(end); | ||||
Michal Klocek
|
r530 | QVector<qreal> result; | ||
Q_ASSERT(startVector.count() == endVecotr.count()) ; | ||||
Jani Honkonen
|
r2097 | for (int i = 0; i < startVector.count(); i++) { | ||
qreal value = startVector[i] + ((endVecotr[i] - startVector[i]) * progress); //qBound(0.0, progress, 1.0)); | ||||
result << value; | ||||
Michal Klocek
|
r530 | } | ||
return qVariantFromValue(result); | ||||
} | ||||
Jani Honkonen
|
r2097 | void AxisAnimation::updateCurrentValue(const QVariant &value) | ||
Michal Klocek
|
r530 | { | ||
Jani Honkonen
|
r2097 | if (state() != QAbstractAnimation::Stopped) { //workaround | ||
Jani Honkonen
|
r2241 | QVector<qreal> vector = qvariant_cast<QVector<qreal> >(value); | ||
Michal Klocek
|
r2407 | // Q_ASSERT(vector.count() != 0); | ||
Michal Klocek
|
r530 | m_axis->setLayout(vector); | ||
Michal Klocek
|
r1241 | m_axis->updateGeometry(); | ||
Michal Klocek
|
r530 | } | ||
} | ||||
QTCOMMERCIALCHART_END_NAMESPACE | ||||