polardomain.cpp
92 lines
| 2.6 KiB
| text/x-c
|
CppLexer
Titta Heikkala
|
r2845 | /****************************************************************************** | ||
Miikka Heikkinen
|
r2483 | ** | ||
Titta Heikkala
|
r2845 | ** Copyright (C) 2015 The Qt Company Ltd. | ||
** Contact: http://www.qt.io/licensing/ | ||||
Miikka Heikkinen
|
r2483 | ** | ||
Titta Heikkala
|
r2740 | ** This file is part of the Qt Charts module. | ||
Miikka Heikkinen
|
r2483 | ** | ||
Titta Heikkala
|
r2845 | ** $QT_BEGIN_LICENSE:COMM$ | ||
Miikka Heikkinen
|
r2483 | ** | ||
Titta Heikkala
|
r2845 | ** 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. | ||||
Miikka Heikkinen
|
r2483 | ** | ||
Titta Heikkala
|
r2845 | ** $QT_END_LICENSE$ | ||
** | ||||
******************************************************************************/ | ||||
Miikka Heikkinen
|
r2483 | |||
Titta Heikkala
|
r2714 | #include <private/polardomain_p.h> | ||
#include <private/qabstractaxis_p.h> | ||||
#include <QtCore/QtMath> | ||||
Miikka Heikkinen
|
r2483 | |||
Titta Heikkala
|
r2712 | QT_CHARTS_BEGIN_NAMESPACE | ||
Miikka Heikkinen
|
r2483 | |||
PolarDomain::PolarDomain(QObject *parent) | ||||
: AbstractDomain(parent) | ||||
{ | ||||
} | ||||
PolarDomain::~PolarDomain() | ||||
{ | ||||
} | ||||
void PolarDomain::setSize(const QSizeF &size) | ||||
{ | ||||
Q_ASSERT(size.width() == size.height()); | ||||
Miikka Heikkinen
|
r2580 | m_radius = size.height() / 2.0; | ||
Miikka Heikkinen
|
r2483 | m_center = QPointF(m_radius, m_radius); | ||
AbstractDomain::setSize(size); | ||||
} | ||||
QPointF PolarDomain::calculateGeometryPoint(const QPointF &point, bool &ok) const | ||||
{ | ||||
Miikka Heikkinen
|
r2580 | qreal r = 0.0; | ||
Miikka Heikkinen
|
r2483 | 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(); | ||||
} | ||||
} | ||||
Miikka Heikkinen
|
r2820 | QVector<QPointF> PolarDomain::calculateGeometryPoints(const QVector<QPointF> &vector) const | ||
Miikka Heikkinen
|
r2483 | { | ||
QVector<QPointF> result; | ||||
result.resize(vector.count()); | ||||
bool ok; | ||||
Miikka Heikkinen
|
r2580 | qreal r = 0.0; | ||
qreal a = 0.0; | ||||
Miikka Heikkinen
|
r2483 | |||
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" | ||||
Titta Heikkala
|
r2712 | QT_CHARTS_END_NAMESPACE | ||