|
|
/******************************************************************************
|
|
|
**
|
|
|
** 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 "charts.h"
|
|
|
#include <QtCharts/QChart>
|
|
|
#include <QtCharts/QLineSeries>
|
|
|
#include <QtCharts/QValueAxis>
|
|
|
#include <QtCharts/QDateTimeAxis>
|
|
|
|
|
|
class DateTimeAxisY: public Chart
|
|
|
{
|
|
|
public:
|
|
|
QString name() { return "AxisY"; }
|
|
|
QString category() { return QObject::tr("Axis"); }
|
|
|
QString subCategory() { return "DateTimeAxis"; }
|
|
|
|
|
|
QChart *createChart(const DataTable &table)
|
|
|
{
|
|
|
QChart *chart = new QChart();
|
|
|
chart->setTitle("Value X , DateTime Y");
|
|
|
QValueAxis *valueaxis = new QValueAxis();
|
|
|
QDateTimeAxis *datetimeaxis = new QDateTimeAxis();
|
|
|
datetimeaxis->setTickCount(10);
|
|
|
datetimeaxis->setFormat("yyyy");
|
|
|
|
|
|
qreal day = 1000l * 60l * 60l * 24l;
|
|
|
|
|
|
QString name("Series ");
|
|
|
int nameIndex = 0;
|
|
|
foreach (DataList list, table) {
|
|
|
QLineSeries *series = new QLineSeries(chart);
|
|
|
foreach (Data data, list) {
|
|
|
QPointF point = data.first;
|
|
|
series->append(point.x(), day * 365l * 30l + point.y() * day * 365l);
|
|
|
}
|
|
|
series->setName(name + QString::number(nameIndex));
|
|
|
nameIndex++;
|
|
|
chart->addSeries(series);
|
|
|
chart->setAxisY(datetimeaxis, series);
|
|
|
chart->setAxisX(valueaxis, series);
|
|
|
}
|
|
|
|
|
|
return chart;
|
|
|
}
|
|
|
};
|
|
|
|
|
|
class DateTimeAxisYTitle: public DateTimeAxisY
|
|
|
{
|
|
|
public:
|
|
|
QString name() { return "AxisY Title"; }
|
|
|
|
|
|
QChart *createChart(const DataTable &table)
|
|
|
{
|
|
|
QChart *chart = DateTimeAxisY::createChart(table);
|
|
|
chart->axisX()->setTitleText("Axis X");
|
|
|
chart->axisY()->setTitleText("Axis Y");
|
|
|
chart->setTitle("Value X , DateTime Y, Title");
|
|
|
return chart;
|
|
|
}
|
|
|
};
|
|
|
|
|
|
DECLARE_CHART(DateTimeAxisY);
|
|
|
DECLARE_CHART(DateTimeAxisYTitle);
|
|
|
|