polarchartlayout.cpp
83 lines
| 2.8 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/polarchartlayout_p.h> | ||
#include <private/chartpresenter_p.h> | ||||
#include <private/polarchartaxis_p.h> | ||||
#include <QtCore/QDebug> | ||||
Miikka Heikkinen
|
r2483 | |||
Titta Heikkala
|
r2712 | QT_CHARTS_BEGIN_NAMESPACE | ||
Miikka Heikkinen
|
r2483 | |||
static const qreal golden_ratio = 0.4; | ||||
PolarChartLayout::PolarChartLayout(ChartPresenter *presenter) | ||||
: AbstractChartLayout(presenter) | ||||
{ | ||||
} | ||||
PolarChartLayout::~PolarChartLayout() | ||||
{ | ||||
} | ||||
QRectF PolarChartLayout::calculateAxisGeometry(const QRectF &geometry, const QList<ChartAxisElement *> &axes) const | ||||
{ | ||||
// How to handle multiple angular/radial axes? | ||||
qreal axisRadius = geometry.height() / 2.0; | ||||
if (geometry.width() < geometry.height()) | ||||
axisRadius = geometry.width() / 2.0; | ||||
int titleHeight = 0; | ||||
foreach (ChartAxisElement *chartAxis, axes) { | ||||
if (!chartAxis->isVisible()) | ||||
continue; | ||||
PolarChartAxis *polarChartAxis = static_cast<PolarChartAxis *>(chartAxis); | ||||
qreal radius = polarChartAxis->preferredAxisRadius(geometry.size()); | ||||
if (radius < axisRadius) | ||||
axisRadius = radius; | ||||
if (chartAxis->axis()->orientation() == Qt::Horizontal | ||||
&& chartAxis->axis()->isTitleVisible() | ||||
&& !chartAxis->axis()->titleText().isEmpty()) { | ||||
// If axis has angular title, adjust geometry down by the space title takes | ||||
Miikka Heikkinen
|
r2539 | QRectF dummyRect = ChartPresenter::textBoundingRect(chartAxis->axis()->titleFont(), chartAxis->axis()->titleText()); | ||
Miikka Heikkinen
|
r2530 | titleHeight = (dummyRect.height() / 2.0) + chartAxis->titlePadding(); | ||
Miikka Heikkinen
|
r2483 | } | ||
} | ||||
QRectF axisRect; | ||||
axisRect.setSize(QSizeF(axisRadius * 2.0, axisRadius * 2.0)); | ||||
axisRect.moveCenter(geometry.center()); | ||||
axisRect.adjust(0, titleHeight, 0, titleHeight); | ||||
foreach (ChartAxisElement *chartAxis, axes) | ||||
chartAxis->setGeometry(axisRect, QRectF()); | ||||
return axisRect; | ||||
} | ||||
QRectF PolarChartLayout::calculateAxisMinimum(const QRectF &minimum, const QList<ChartAxisElement *> &axes) const | ||||
{ | ||||
Q_UNUSED(axes); | ||||
return minimum; | ||||
} | ||||
Titta Heikkala
|
r2712 | QT_CHARTS_END_NAMESPACE | ||