##// END OF EJS Templates
Accelerating lineseries with OpenGL...
Accelerating lineseries with OpenGL Added support for QAbstractSeries::useOpenGL property. When true, the series in question is drawn on a separate offscreen buffer using OpenGL and then superimposed on the chart. Currently this property is only supported for line and scatter series. Change-Id: I174fec541f9f3c23464270c1fe08f824af16a0fb Reviewed-by: Titta Heikkala <titta.heikkala@theqtcompany.com> Reviewed-by: Tomi Korpipää <tomi.korpipaa@theqtcompany.com>

File last commit:

r2820:79a856530b69
r2820:79a856530b69
Show More
polardomain.cpp
89 lines | 2.5 KiB | text/x-c | CppLexer
Miikka Heikkinen
Add Polar chart support...
r2483 /****************************************************************************
**
Titta Heikkala
Copyright header changes...
r2776 ** Copyright (C) 2015 The Qt Company Ltd
Miikka Heikkinen
Add Polar chart support...
r2483 ** All rights reserved.
Titta Heikkala
Copyright header changes...
r2776 ** For any questions to The Qt Company, please use contact form at http://qt.io
Miikka Heikkinen
Add Polar chart support...
r2483 **
Titta Heikkala
Updated license headers...
r2740 ** This file is part of the Qt Charts module.
Miikka Heikkinen
Add Polar chart support...
r2483 **
Titta Heikkala
Updated license headers...
r2740 ** Licensees holding valid commercial license for Qt may use this file in
** accordance with the Qt License Agreement provided with the Software
** or, alternatively, in accordance with the terms contained in a written
Titta Heikkala
Copyright header changes...
r2776 ** agreement between you and The Qt Company.
Miikka Heikkinen
Add Polar chart support...
r2483 **
** If you have questions regarding the use of this file, please use
Titta Heikkala
Updated license headers...
r2740 ** contact form at http://qt.io
Miikka Heikkinen
Add Polar chart support...
r2483 **
****************************************************************************/
Titta Heikkala
Fix include syntax...
r2714 #include <private/polardomain_p.h>
#include <private/qabstractaxis_p.h>
#include <QtCore/QtMath>
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Qt Charts project file structure change...
r2712 QT_CHARTS_BEGIN_NAMESPACE
Miikka Heikkinen
Add Polar chart support...
r2483
PolarDomain::PolarDomain(QObject *parent)
: AbstractDomain(parent)
{
}
PolarDomain::~PolarDomain()
{
}
void PolarDomain::setSize(const QSizeF &size)
{
Q_ASSERT(size.width() == size.height());
Miikka Heikkinen
Fix warning about uninitialized variable...
r2580 m_radius = size.height() / 2.0;
Miikka Heikkinen
Add Polar chart support...
r2483 m_center = QPointF(m_radius, m_radius);
AbstractDomain::setSize(size);
}
QPointF PolarDomain::calculateGeometryPoint(const QPointF &point, bool &ok) const
{
Miikka Heikkinen
Fix warning about uninitialized variable...
r2580 qreal r = 0.0;
Miikka Heikkinen
Add Polar chart support...
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
Accelerating lineseries with OpenGL...
r2820 QVector<QPointF> PolarDomain::calculateGeometryPoints(const QVector<QPointF> &vector) const
Miikka Heikkinen
Add Polar chart support...
r2483 {
QVector<QPointF> result;
result.resize(vector.count());
bool ok;
Miikka Heikkinen
Fix warning about uninitialized variable...
r2580 qreal r = 0.0;
qreal a = 0.0;
Miikka Heikkinen
Add Polar chart support...
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
Qt Charts project file structure change...
r2712 QT_CHARTS_END_NAMESPACE