/**************************************************************************** ** ** 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 "baranimation_p.h" #include "barchartitem_p.h" #include #include Q_DECLARE_METATYPE(QVector) //Q_DECLARE_METATYPE(BarLayout) // TODO? QTCOMMERCIALCHART_BEGIN_NAMESPACE BarAnimation::BarAnimation(BarChartItem *item) :ChartAnimation(item), m_item(item) { } BarAnimation::~BarAnimation() { } QVariant BarAnimation::interpolated(const QVariant &from, const QVariant &to, qreal progress) const { QVector startVector = qVariantValue >(from); QVector endVector = qVariantValue >(to); QVector result; Q_ASSERT(startVector.count() == endVector.count()); for(int i = 0; i < startVector.count(); i++) { qreal w = endVector[i].width(); qreal h = startVector[i].height() + ((endVector[i].height() - startVector[i].height()) * progress); qreal x = endVector[i].topLeft().x(); qreal y = endVector[i].topLeft().y() + endVector[i].height() - h; QPointF topLeft(x,y); QSizeF size(w,h); QRectF value(topLeft,size); result << value; } return qVariantFromValue(result); } void BarAnimation::updateCurrentValue(const QVariant &value) { QVector layout = qVariantValue >(value); m_item->setLayout(layout); } #include "moc_baranimation_p.cpp" QTCOMMERCIALCHART_END_NAMESPACE