/**************************************************************************** ** ** 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 "abstractbarchartitem_p.h" #include Q_DECLARE_METATYPE(QVector) QTCOMMERCIALCHART_BEGIN_NAMESPACE BarAnimation::BarAnimation(AbstractBarChartItem *item) : AbstractBarAnimation(item) { } BarAnimation::~BarAnimation() { } QVariant BarAnimation::interpolated(const QVariant &from, const QVariant &to, qreal progress) const { QVector startVector = qvariant_cast >(from); QVector endVector = qvariant_cast >(to); QVector result; Q_ASSERT(startVector.count() == endVector.count()); for (int i = 0; i < startVector.count(); i++) { QRectF start = startVector[i].normalized(); QRectF end = endVector[i].normalized(); qreal x = end.left(); qreal y; qreal w = end.width(); qreal h; if (endVector[i].height() < 0) { // Negative bar y = end.top(); h = start.height() + ((end.height() - start.height()) * progress); } else { h = startVector[i].height() + ((endVector[i].height() - startVector[i].height()) * progress); y = endVector[i].top() + endVector[i].height() - h; } QRectF value(x, y, w, h); result << value.normalized(); } return qVariantFromValue(result); } #include "moc_baranimation_p.cpp" QTCOMMERCIALCHART_END_NAMESPACE