##// END OF EJS Templates
Fix model resetting in with model mappers...
Fix model resetting in with model mappers Change-Id: I22afd1d361aaf0561b4d94b6a3656bfe7b0d9812 Reviewed-by: Miikka Heikkinen <miikka.heikkinen@theqtcompany.com>

File last commit:

r2845:ae12522d475c
r2870:ea9744cf9a34
Show More
polarchartdatetimeaxisradial.cpp
80 lines | 2.5 KiB | text/x-c | CppLexer
/ src / charts / axis / datetimeaxis / polarchartdatetimeaxisradial.cpp
/******************************************************************************
**
** Copyright (C) 2015 The Qt Company Ltd.
** Contact: http://www.qt.io/licensing/
**
** This file is part of the Qt Charts module.
**
** $QT_BEGIN_LICENSE:COMM$
**
** 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.
**
** $QT_END_LICENSE$
**
******************************************************************************/
#include <private/polarchartdatetimeaxisradial_p.h>
#include <private/chartpresenter_p.h>
#include <private/abstractchartlayout_p.h>
#include <QtCharts/QDateTimeAxis>
QT_CHARTS_BEGIN_NAMESPACE
PolarChartDateTimeAxisRadial::PolarChartDateTimeAxisRadial(QDateTimeAxis *axis, QGraphicsItem *item)
: PolarChartAxisRadial(axis, item)
{
QObject::connect(axis, SIGNAL(tickCountChanged(int)), this, SLOT(handleTickCountChanged(int)));
QObject::connect(axis, SIGNAL(formatChanged(QString)), this, SLOT(handleFormatChanged(QString)));
}
PolarChartDateTimeAxisRadial::~PolarChartDateTimeAxisRadial()
{
}
QVector<qreal> PolarChartDateTimeAxisRadial::calculateLayout() const
{
int tickCount = static_cast<QDateTimeAxis *>(axis())->tickCount();
Q_ASSERT(tickCount >= 2);
QVector<qreal> points;
points.resize(tickCount);
const qreal d = (axisGeometry().width() / 2) / qreal(tickCount - 1);
for (int i = 0; i < tickCount; ++i) {
qreal radialCoordinate = qreal(i) * d;
points[i] = radialCoordinate;
}
return points;
}
void PolarChartDateTimeAxisRadial::createAxisLabels(const QVector<qreal> &layout)
{
setLabels(createDateTimeLabels(min(), max(), layout.size(), static_cast<QDateTimeAxis *>(axis())->format()));
}
void PolarChartDateTimeAxisRadial::handleTickCountChanged(int tick)
{
Q_UNUSED(tick);
QGraphicsLayoutItem::updateGeometry();
if (presenter())
presenter()->layout()->invalidate();
}
void PolarChartDateTimeAxisRadial::handleFormatChanged(const QString &format)
{
Q_UNUSED(format);
QGraphicsLayoutItem::updateGeometry();
if (presenter())
presenter()->layout()->invalidate();
}
#include "moc_polarchartdatetimeaxisradial_p.cpp"
QT_CHARTS_END_NAMESPACE