##// END OF EJS Templates
Removed the old hovered signal from bar chart...
Removed the old hovered signal from bar chart A new hovered signal that provides index information has been added for bar chart (QTRD-2161). The old hovered signal has now been removed. Change-Id: Ia65be1c363cbfda942d48bceb5326bd54a3c35ec Task-number: QTRD-2199 Reviewed-by: Miikka Heikkinen <miikka.heikkinen@theqtcompany.com> Reviewed-by: Mika Salmela <mika.salmela@theqtcompany.com>

File last commit:

r2714:929d943d1aab
r2726:17ddbeb77815
Show More
polardomain.cpp
91 lines | 2.6 KiB | text/x-c | CppLexer
/****************************************************************************
**
** Copyright (C) 2014 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 Enterprise Charts Add-on.
**
** $QT_BEGIN_LICENSE$
** Licensees holding valid Qt Enterprise licenses may use this file in
** accordance with the Qt Enterprise 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 <private/polardomain_p.h>
#include <private/qabstractaxis_p.h>
#include <QtCore/QtMath>
QT_CHARTS_BEGIN_NAMESPACE
PolarDomain::PolarDomain(QObject *parent)
: AbstractDomain(parent)
{
}
PolarDomain::~PolarDomain()
{
}
void PolarDomain::setSize(const QSizeF &size)
{
Q_ASSERT(size.width() == size.height());
m_radius = size.height() / 2.0;
m_center = QPointF(m_radius, m_radius);
AbstractDomain::setSize(size);
}
QPointF PolarDomain::calculateGeometryPoint(const QPointF &point, bool &ok) const
{
qreal r = 0.0;
qreal a = toAngularCoordinate(point.x(), ok);
if (ok)
r = toRadialCoordinate(point.y(), ok);
if (ok) {
return m_center + polarCoordinateToPoint(a, r);
} else {
qWarning() << "Logarithm of negative value is undefined. Empty layout returned.";
return QPointF();
}
}
QVector<QPointF> PolarDomain::calculateGeometryPoints(const QList<QPointF> &vector) const
{
QVector<QPointF> result;
result.resize(vector.count());
bool ok;
qreal r = 0.0;
qreal a = 0.0;
for (int i = 0; i < vector.count(); ++i) {
a = toAngularCoordinate(vector[i].x(), ok);
if (ok)
r = toRadialCoordinate(vector[i].y(), ok);
if (ok) {
result[i] = m_center + polarCoordinateToPoint(a, r);
} else {
qWarning() << "Logarithm of negative value is undefined. Empty layout returned.";
return QVector<QPointF>();
}
}
return result;
}
QPointF PolarDomain::polarCoordinateToPoint(qreal angularCoordinate, qreal radialCoordinate) const
{
qreal dx = qSin(angularCoordinate * (M_PI / 180)) * radialCoordinate;
qreal dy = qCos(angularCoordinate * (M_PI / 180)) * radialCoordinate;
return QPointF(dx, -dy);
}
#include "moc_polardomain_p.cpp"
QT_CHARTS_END_NAMESPACE