Model Data Example▲
Sélectionnez
/**
**************************************************************************
**
** Copyright (C) 2016 The Qt Company Ltd.
** Contact: https://www.qt.io/licensing/
**
** This file is part of the Qt Charts module of the Qt Toolkit.
**
** $QT_BEGIN_LICENSE:GPL$
** 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 https://www.qt.io/terms-conditions. For further
** information use the contact form at https://www.qt.io/contact-us.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3 or (at your option) any later version
** approved by the KDE Free Qt Foundation. The licenses are as published by
** the Free Software Foundation and appearing in the file LICENSE.GPL3
** included in the packaging of this file. Please review the following
** information to ensure the GNU General Public License requirements will
** be met: https://www.gnu.org/licenses/gpl-3.0.html.
**
** $QT_END_LICENSE$
**
***************************************************************************
*/
#include
"tablewidget.h"
#include
"customtablemodel.h"
#include <QtWidgets/QGridLayout>
#include <QtWidgets/QTableView>
#include <QtCharts/QChart>
#include <QtCharts/QChartView>
#include <QtCharts/QLineSeries>
#include <QtCharts/QVXYModelMapper>
#include <QtWidgets/QHeaderView>
QT_CHARTS_USE_NAMESPACE
TableWidget::
TableWidget(QWidget *
parent)
:
QWidget(parent)
{
// create simple model for storing data
// user's table data model
CustomTableModel *
model =
new
CustomTableModel;
// create table view and add model to it
QTableView *
tableView =
new
QTableView;
tableView-&
gt;setModel(model);
tableView-&
gt;horizontalHeader()-&
gt;setSectionResizeMode(QHeaderView::
Stretch);
tableView-&
gt;verticalHeader()-&
gt;setSectionResizeMode(QHeaderView::
Stretch);
QChart *
chart =
new
QChart;
chart-&
gt;setAnimationOptions(QChart::
AllAnimations);
// series 1
QLineSeries *
series =
new
QLineSeries;
series-&
gt;setName("Line 1"
);
QVXYModelMapper *
mapper =
new
QVXYModelMapper(this
);
mapper-&
gt;setXColumn(0
);
mapper-&
gt;setYColumn(1
);
mapper-&
gt;setSeries(series);
mapper-&
gt;setModel(model);
chart-&
gt;addSeries(series);
// for storing color hex from the series
QString seriesColorHex =
"#000000"
;
// get the color of the series and use it for showing the mapped area
seriesColorHex =
"#"
+
QString::
number(series-&
gt;pen().color().rgb(), 16
).right(6
).toUpper();
model-&
gt;addMapping(seriesColorHex, QRect(0
, 0
, 2
, model-&
gt;rowCount()));
// series 2
series =
new
QLineSeries;
series-&
gt;setName("Line 2"
);
mapper =
new
QVXYModelMapper(this
);
mapper-&
gt;setXColumn(2
);
mapper-&
gt;setYColumn(3
);
mapper-&
gt;setSeries(series);
mapper-&
gt;setModel(model);
chart-&
gt;addSeries(series);
// get the color of the series and use it for showing the mapped area
seriesColorHex =
"#"
+
QString::
number(series-&
gt;pen().color().rgb(), 16
).right(6
).toUpper();
model-&
gt;addMapping(seriesColorHex, QRect(2
, 0
, 2
, model-&
gt;rowCount()));
chart-&
gt;createDefaultAxes();
QChartView *
chartView =
new
QChartView(chart);
chartView-&
gt;setRenderHint(QPainter::
Antialiasing);
chartView-&
gt;setMinimumSize(640
, 480
);
// create main layout
QGridLayout *
mainLayout =
new
QGridLayout;
mainLayout-&
gt;addWidget(tableView, 1
, 0
);
mainLayout-&
gt;addWidget(chartView, 1
, 1
);
mainLayout-&
gt;setColumnStretch(1
, 1
);
mainLayout-&
gt;setColumnStretch(0
, 0
);
setLayout(mainLayout);
}