BarModelMapper 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 <QtWidgets/QGridLayout>
#include <QtWidgets/QTableView>
#include <QtCharts/QChart>
#include <QtCharts/QChartView>
#include <QtCharts/QLineSeries>
#include <QtCharts/QVXYModelMapper>
#include <QtCharts/QBarSeries>
#include <QtCharts/QBarSet>
#include <QtCharts/QVBarModelMapper>
#include <QtWidgets/QHeaderView>
#include <QtCharts/QBarCategoryAxis>
#include <QtCharts/QValueAxis>
QT_CHARTS_USE_NAMESPACE
TableWidget::
TableWidget(QWidget *
parent)
:
QWidget(parent)
{
// create simple model for storing data
// user's table data model
m_model =
new
CustomTableModel;
// create table view and add model to it
QTableView *
tableView =
new
QTableView;
tableView-&
gt;setModel(m_model);
tableView-&
gt;setMinimumWidth(300
);
tableView-&
gt;horizontalHeader()-&
gt;setSectionResizeMode(QHeaderView::
Stretch);
tableView-&
gt;verticalHeader()-&
gt;setSectionResizeMode(QHeaderView::
Stretch);
m_model-&
gt;setParent(tableView);
QChart *
chart =
new
QChart;
chart-&
gt;setAnimationOptions(QChart::
AllAnimations);
// series 1
QBarSeries *
series =
new
QBarSeries;
int
first =
3
;
int
count =
5
;
QVBarModelMapper *
mapper =
new
QVBarModelMapper(this
);
mapper-&
gt;setFirstBarSetColumn(1
);
mapper-&
gt;setLastBarSetColumn(4
);
mapper-&
gt;setFirstRow(first);
mapper-&
gt;setRowCount(count);
mapper-&
gt;setSeries(series);
mapper-&
gt;setModel(m_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
QList&
lt;QBarSet *&
gt; barsets =
series-&
gt;barSets();
for
(int
i =
0
; i &
lt; barsets.count(); i++
) {
seriesColorHex =
"#"
+
QString::
number(barsets.at(i)-&
gt;brush().color().rgb(), 16
).right(6
).toUpper();
m_model-&
gt;addMapping(seriesColorHex, QRect(1
+
i, first, 1
, barsets.at(i)-&
gt;count()));
}
QStringList categories;
categories &
lt;&
lt; "April"
&
lt;&
lt; "May"
&
lt;&
lt; "June"
&
lt;&
lt; "July"
&
lt;&
lt; "August"
;
QBarCategoryAxis *
axisX =
new
QBarCategoryAxis();
axisX-&
gt;append(categories);
chart-&
gt;addAxis(axisX, Qt::
AlignBottom);
series-&
gt;attachAxis(axisX);
QValueAxis *
axisY =
new
QValueAxis();
chart-&
gt;addAxis(axisY, Qt::
AlignLeft);
series-&
gt;attachAxis(axisY);
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);
}