##// END OF EJS Templates
Check that areaseries is actually in chart before trying to update....
Check that areaseries is actually in chart before trying to update. When a line series is used both as a series on chart and as an area series boundary, but not at the same time, animation can sometimes get confused as to what series to update if the area series is removed from the chart and the line series is added to the chart while a series animation is running. Task-number: QTRD-3445 Change-Id: Ia3d72d3ceba784b6e162b2c9b678acdc3e3ffcac Reviewed-by: Titta Heikkala <titta.heikkala@theqtcompany.com>

File last commit:

r2794:05fa3caa7879
r2800:891ed0097501
Show More
abstractchartlayout.cpp
201 lines | 6.8 KiB | text/x-c | CppLexer
/ src / charts / layout / abstractchartlayout.cpp
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/abstractchartlayout_p.h>
#include <private/chartpresenter_p.h>
#include <private/qlegend_p.h>
#include <private/chartaxiselement_p.h>
#include <private/charttitle_p.h>
#include <private/chartbackground_p.h>
#include <QtCore/QDebug>
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
static const qreal golden_ratio = 0.4;
AbstractChartLayout::AbstractChartLayout(ChartPresenter *presenter)
: m_presenter(presenter),
m_margins(20, 20, 20, 20),
m_minChartRect(0, 0, 200, 200)
{
}
AbstractChartLayout::~AbstractChartLayout()
{
}
void AbstractChartLayout::setGeometry(const QRectF &rect)
{
if (!rect.isValid())
return;
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 if (m_presenter->chart()->isVisible()) {
QList<ChartAxisElement *> axes = m_presenter->axisItems();
ChartTitle *title = m_presenter->titleElement();
QLegend *legend = m_presenter->legend();
ChartBackground *background = m_presenter->backgroundElement();
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 QRectF contentGeometry = calculateBackgroundGeometry(rect, background);
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 contentGeometry = calculateContentGeometry(contentGeometry);
Miikka Heikkinen
Add Polar chart support...
r2483
Miikka Heikkinen
Don't reserve space for chart title if it is empty....
r2794 if (title && title->isVisible() && !title->text().isEmpty())
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 contentGeometry = calculateTitleGeometry(contentGeometry, title);
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 if (legend->isAttachedToChart() && legend->isVisible())
contentGeometry = calculateLegendGeometry(contentGeometry, legend);
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 contentGeometry = calculateAxisGeometry(contentGeometry, axes);
Miikka Heikkinen
Add Polar chart support...
r2483
Titta Heikkala
Fix ChartView visibility change drawing...
r2605 m_presenter->setGeometry(contentGeometry);
if (m_presenter->chart()->chartType() == QChart::ChartTypeCartesian)
static_cast<QGraphicsRectItem *>(m_presenter->plotAreaElement())->setRect(contentGeometry);
else
static_cast<QGraphicsEllipseItem *>(m_presenter->plotAreaElement())->setRect(contentGeometry);
}
Miikka Heikkinen
Add Polar chart support...
r2483
QGraphicsLayout::setGeometry(rect);
}
QRectF AbstractChartLayout::calculateContentGeometry(const QRectF &geometry) const
{
return geometry.adjusted(m_margins.left(), m_margins.top(), -m_margins.right(), -m_margins.bottom());
}
QRectF AbstractChartLayout::calculateContentMinimum(const QRectF &minimum) const
{
return minimum.adjusted(0, 0, m_margins.left() + m_margins.right(), m_margins.top() + m_margins.bottom());
}
QRectF AbstractChartLayout::calculateBackgroundGeometry(const QRectF &geometry, ChartBackground *background) const
{
qreal left;
qreal top;
qreal right;
qreal bottom;
getContentsMargins(&left, &top, &right, &bottom);
QRectF backgroundGeometry = geometry.adjusted(left, top, -right, -bottom);
if (background)
background->setRect(backgroundGeometry);
return backgroundGeometry;
}
QRectF AbstractChartLayout::calculateBackgroundMinimum(const QRectF &minimum) const
{
qreal left;
qreal top;
qreal right;
qreal bottom;
getContentsMargins(&left, &top, &right, &bottom);
return minimum.adjusted(0, 0, left + right, top + bottom);
}
QRectF AbstractChartLayout::calculateLegendGeometry(const QRectF &geometry, QLegend *legend) const
{
QSizeF size = legend->effectiveSizeHint(Qt::PreferredSize, QSizeF(-1, -1));
QRectF legendRect;
QRectF result;
switch (legend->alignment()) {
case Qt::AlignTop: {
legendRect = QRectF(geometry.topLeft(), QSizeF(geometry.width(), size.height()));
result = geometry.adjusted(0, legendRect.height(), 0, 0);
break;
}
case Qt::AlignBottom: {
legendRect = QRectF(QPointF(geometry.left(), geometry.bottom() - size.height()), QSizeF(geometry.width(), size.height()));
result = geometry.adjusted(0, 0, 0, -legendRect.height());
break;
}
case Qt::AlignLeft: {
qreal width = qMin(size.width(), geometry.width() * golden_ratio);
legendRect = QRectF(geometry.topLeft(), QSizeF(width, geometry.height()));
result = geometry.adjusted(width, 0, 0, 0);
break;
}
case Qt::AlignRight: {
qreal width = qMin(size.width(), geometry.width() * golden_ratio);
legendRect = QRectF(QPointF(geometry.right() - width, geometry.top()), QSizeF(width, geometry.height()));
result = geometry.adjusted(0, 0, -width, 0);
break;
}
default: {
legendRect = QRectF(0, 0, 0, 0);
result = geometry;
break;
}
}
legend->setGeometry(legendRect);
return result;
}
QRectF AbstractChartLayout::calculateLegendMinimum(const QRectF &geometry, QLegend *legend) const
{
QSizeF minSize = legend->effectiveSizeHint(Qt::MinimumSize, QSizeF(-1, -1));
return geometry.adjusted(0, 0, minSize.width(), minSize.height());
}
QRectF AbstractChartLayout::calculateTitleGeometry(const QRectF &geometry, ChartTitle *title) const
{
title->setGeometry(geometry);
QPointF center = geometry.center() - title->boundingRect().center();
title->setPos(center.x(), title->pos().y());
return geometry.adjusted(0, title->boundingRect().height()+1, 0, 0);
}
QRectF AbstractChartLayout::calculateTitleMinimum(const QRectF &minimum, ChartTitle *title) const
{
QSizeF min = title->sizeHint(Qt::MinimumSize);
return minimum.adjusted(0, 0, min.width(), min.height());
}
QSizeF AbstractChartLayout::sizeHint(Qt::SizeHint which, const QSizeF &constraint) const
{
Q_UNUSED(constraint);
if (which == Qt::MinimumSize) {
QList<ChartAxisElement *> axes = m_presenter->axisItems();
ChartTitle *title = m_presenter->titleElement();
QLegend *legend = m_presenter->legend();
QRectF minimumRect(0, 0, 0, 0);
minimumRect = calculateBackgroundMinimum(minimumRect);
minimumRect = calculateContentMinimum(minimumRect);
minimumRect = calculateTitleMinimum(minimumRect, title);
minimumRect = calculateLegendMinimum(minimumRect, legend);
minimumRect = calculateAxisMinimum(minimumRect, axes);
return minimumRect.united(m_minChartRect).size().toSize();
}
return QSize(-1, -1);
}
void AbstractChartLayout::setMargins(const QMargins &margins)
{
if (m_margins != margins) {
m_margins = margins;
updateGeometry();
}
}
QMargins AbstractChartLayout::margins() const
{
return m_margins;
}
Titta Heikkala
Qt Charts project file structure change...
r2712 QT_CHARTS_END_NAMESPACE