/**************************************************************************** ** ** 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$ ** ****************************************************************************/ #include "xyanimation_p.h" #include "xychartitem_p.h" Q_DECLARE_METATYPE(QVector) QTCOMMERCIALCHART_BEGIN_NAMESPACE XYAnimation::XYAnimation(XYChartItem *item):ChartAnimation(item), m_item(item), m_dirty(false) { } XYAnimation::~XYAnimation() { } void XYAnimation::setValues(QVector &oldPoints, QVector &newPoints, int index) { int x = oldPoints.count(); int y = newPoints.count(); if (x != y && abs(x - y) != 1) { m_oldPoints = newPoints; oldPoints.resize(newPoints.size()); setKeyValueAt(0.0, qVariantFromValue(oldPoints)); setKeyValueAt(1.0, qVariantFromValue(newPoints)); m_dirty = false; } else { if (m_dirty) { m_oldPoints = oldPoints; m_dirty = false; } oldPoints = newPoints; if (y < x) m_oldPoints.remove(index); //remove if (y > x) m_oldPoints.insert(index, x > 0 ? m_oldPoints[index-1] : newPoints[index]); //add setKeyValueAt(0.0, qVariantFromValue(m_oldPoints)); setKeyValueAt(1.0, qVariantFromValue(newPoints)); Q_ASSERT(m_oldPoints.count() == newPoints.count()); } } QVariant XYAnimation::interpolated(const QVariant &start, const QVariant &end, qreal progress ) const { QVector startVector = qVariantValue >(start); QVector endVector = qVariantValue >(end); QVector result; switch (m_type) { case MoveDownAnimation: { if (startVector.count() != endVector.count()) break; for(int i = 0; i < startVector.count(); i++) { qreal x = startVector[i].x() + ((endVector[i].x() - startVector[i].x()) * progress); qreal y = startVector[i].y() + ((endVector[i].y() - startVector[i].y()) * progress); result << QPointF(x, y); } } break; case LineDrawAnimation: { for(int i = 0; i < endVector.count() * qBound(qreal(0), progress, qreal(1)); i++) result << endVector[i]; } break; default: qWarning() << "Unknown type of animation"; break; } return qVariantFromValue(result); } void XYAnimation::updateCurrentValue (const QVariant &value) { if(state()!=QAbstractAnimation::Stopped){ //workaround m_dirty = true; QVector vector = qVariantValue >(value); m_item->setLayout(vector); } } QTCOMMERCIALCHART_END_NAMESPACE