/****************************************************************************** ** ** Copyright (C) 2015 The Qt Company Ltd. ** Contact: http://www.qt.io/licensing/ ** ** This file is part of the Qt Charts module. ** ** $QT_BEGIN_LICENSE:COMM$ ** ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see http://www.qt.io/terms-conditions. For further ** information use the contact form at http://www.qt.io/contact-us. ** ** $QT_END_LICENSE$ ** ******************************************************************************/ #include #include #include Q_DECLARE_METATYPE(QVector) QT_CHARTS_BEGIN_NAMESPACE AxisAnimation::AxisAnimation(ChartAxisElement *axis, int duration, QEasingCurve &curve) : ChartAnimation(axis), m_axis(axis), m_type(DefaultAnimation) { setDuration(duration); setEasingCurve(curve); } AxisAnimation::~AxisAnimation() { } void AxisAnimation::setAnimationType(Animation type) { if (state() != QAbstractAnimation::Stopped) stop(); m_type = type; } void AxisAnimation::setAnimationPoint(const QPointF &point) { if (state() != QAbstractAnimation::Stopped) stop(); m_point = point; } void AxisAnimation::setValues(QVector &oldLayout, QVector &newLayout) { if (state() != QAbstractAnimation::Stopped) stop(); switch (m_type) { case ZoomOutAnimation: { QRectF rect = m_axis->gridGeometry(); oldLayout.resize(newLayout.count()); for (int i = 0, j = oldLayout.count() - 1; i < (oldLayout.count() + 1) / 2; ++i, --j) { oldLayout[i] = m_axis->axis()->orientation() == Qt::Horizontal ? rect.left() : rect.bottom(); oldLayout[j] = m_axis->axis()->orientation() == Qt::Horizontal ? rect.right() : rect.top(); } } break; case ZoomInAnimation: { int index = qMin(oldLayout.count() * (m_axis->axis()->orientation() == Qt::Horizontal ? m_point.x() : (1 - m_point.y())), newLayout.count() - (qreal)1.0); oldLayout.resize(newLayout.count()); if (index < 0) break; for (int i = 0; i < oldLayout.count(); i++) oldLayout[i] = oldLayout[index]; } break; case MoveForwardAnimation: { oldLayout.resize(newLayout.count()); 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) oldLayout[i] = m_axis->axis()->orientation() == Qt::Horizontal ? rect.left() : rect.top(); } break; } QVariantAnimation::KeyValues value; setKeyValues(value); //workaround for wrong interpolation call setKeyValueAt(0.0, qVariantFromValue(oldLayout)); setKeyValueAt(1.0, qVariantFromValue(newLayout)); } QVariant AxisAnimation::interpolated(const QVariant &start, const QVariant &end, qreal progress) const { QVector startVector = qvariant_cast >(start); QVector endVecotr = qvariant_cast >(end); QVector result; Q_ASSERT(startVector.count() == endVecotr.count()) ; for (int i = 0; i < startVector.count(); i++) { qreal value = startVector[i] + ((endVecotr[i] - startVector[i]) * progress); result << value; } return qVariantFromValue(result); } void AxisAnimation::updateCurrentValue(const QVariant &value) { if (state() != QAbstractAnimation::Stopped) { //workaround QVector vector = qvariant_cast >(value); m_axis->setLayout(vector); m_axis->updateGeometry(); } } QT_CHARTS_END_NAMESPACE