qvxymodelmapper.cpp
237 lines
| 6.5 KiB
| text/x-c
|
CppLexer
Marek Rosa
|
r1355 | /**************************************************************************** | ||
** | ||||
Miikka Heikkinen
|
r2432 | ** Copyright (C) 2013 Digia Plc | ||
Marek Rosa
|
r1355 | ** All rights reserved. | ||
** For any questions to Digia, please use contact form at http://qt.digia.com | ||||
** | ||||
Miikka Heikkinen
|
r2574 | ** This file is part of the Qt Enterprise Charts Add-on. | ||
Marek Rosa
|
r1355 | ** | ||
** $QT_BEGIN_LICENSE$ | ||||
Miikka Heikkinen
|
r2574 | ** Licensees holding valid Qt Enterprise licenses may use this file in | ||
** accordance with the Qt Enterprise License Agreement provided with the | ||||
Marek Rosa
|
r1355 | ** Software or, alternatively, in accordance with the terms contained in | ||
** a written agreement between you and Digia. | ||||
** | ||||
** If you have questions regarding the use of this file, please use | ||||
** contact form at http://qt.digia.com | ||||
** $QT_END_LICENSE$ | ||||
** | ||||
****************************************************************************/ | ||||
Marek Rosa
|
r1252 | #include "qvxymodelmapper.h" | ||
QTCOMMERCIALCHART_BEGIN_NAMESPACE | ||||
Marek Rosa
|
r1331 | /*! | ||
\class QVXYModelMapper | ||||
\mainclass | ||||
Marek Rosa
|
r1397 | Model mappers allow you to use QAbstractItemModel derived models as a data source for a chart series. | ||
Marek Rosa
|
r1379 | Vertical model mapper is used to create a connection between QXYSeries and QAbstractItemModel derived model object. | ||
It is possible to use both QAbstractItemModel and QXYSeries model API. QXYModelMapper makes sure that QXYSeries and the model are kept in sync. | ||||
Marek Rosa
|
r2396 | Note: used model has to support adding/removing rows/columns and modifying the data of the cells. | ||
Marek Rosa
|
r1331 | */ | ||
Tero Ahola
|
r1516 | /*! | ||
\qmlclass VXYModelMapper QHXYModelMapper | ||||
VXYModelMapper allows you to use your own QAbstractItemModel derived model with data in columns as a data source | ||||
for XYSeries based series. It is possible to use both QAbstractItemModel and XYSeries data API to manipulate data. | ||||
VYModelMapper keeps the series and the model in sync. | ||||
*/ | ||||
Marek Rosa
|
r1331 | |||
Marek Rosa
|
r1507 | /*! | ||
\property QVXYModelMapper::series | ||||
\brief Defines the QXYSeries object that is used by the mapper. | ||||
Miikka Heikkinen
|
r2520 | |||
Marek Rosa
|
r1507 | All the data in the series is discarded when it is set to the mapper. | ||
When new series is specified the old series is disconnected (it preserves its data) | ||||
*/ | ||||
Tero Ahola
|
r1516 | /*! | ||
\qmlproperty XYSeries VXYModelMapper::series | ||||
Tero Ahola
|
r1519 | Defines the XYSeries object that is used by the mapper. All the data in the series is discarded when it is set to | ||
Tero Ahola
|
r1516 | the mapper. When new series is specified the old series is disconnected (it preserves its data). | ||
*/ | ||||
Marek Rosa
|
r1507 | |||
/*! | ||||
\property QVXYModelMapper::model | ||||
\brief Defines the model that is used by the mapper. | ||||
*/ | ||||
Tero Ahola
|
r1516 | /*! | ||
\qmlproperty SomeModel VXYModelMapper::model | ||||
The QAbstractItemModel based model that is used by the mapper. You need to implement the model and expose it to | ||||
Marek Rosa
|
r2396 | QML as shown in \l {QML Custom Model} demo application. Note: the model has to support adding/removing rows/columns | ||
Tero Ahola
|
r1516 | and modifying the data of the cells. | ||
*/ | ||||
Marek Rosa
|
r1507 | |||
Marek Rosa
|
r1344 | /*! | ||
\property QVXYModelMapper::xColumn | ||||
Miikka Heikkinen
|
r2520 | \brief Defines which column of the model is kept in sync with the x values of QXYSeries. | ||
Marek Rosa
|
r1344 | Default value is: -1 (invalid mapping) | ||
*/ | ||||
Tero Ahola
|
r1516 | /*! | ||
\qmlproperty int VXYModelMapper::xColumn | ||||
Tero Ahola
|
r1519 | Defines which column of the model is kept in sync with the x values of the series. Default value is -1 (invalid | ||
Tero Ahola
|
r1516 | mapping). | ||
*/ | ||||
Marek Rosa
|
r1344 | |||
/*! | ||||
\property QVXYModelMapper::yColumn | ||||
Miikka Heikkinen
|
r2520 | \brief Defines which column of the model is kept in sync with the y values of QXYSeries. | ||
Marek Rosa
|
r1344 | Default value is: -1 (invalid mapping) | ||
*/ | ||||
Tero Ahola
|
r1516 | /*! | ||
\qmlproperty int VXYModelMapper::yColumn | ||||
Tero Ahola
|
r1519 | Defines which column of the model is kept in sync with the y values of the series. Default value is -1 (invalid | ||
Tero Ahola
|
r1516 | mapping). | ||
*/ | ||||
Marek Rosa
|
r1344 | |||
Marek Rosa
|
r1507 | /*! | ||
\property QVXYModelMapper::firstRow | ||||
\brief Defines which row of the model contains the data for the first point of the series. | ||||
Miikka Heikkinen
|
r2520 | |||
Marek Rosa
|
r1507 | Minimal and default value is: 0 | ||
*/ | ||||
/*! | ||||
Tero Ahola
|
r1516 | \qmlproperty int VXYModelMapper::firstRow | ||
Marek Rosa
|
r1507 | Defines which row of the model contains the data for the first point of the series. | ||
The default value is 0. | ||||
*/ | ||||
/*! | ||||
\property QVXYModelMapper::rowCount | ||||
Miikka Heikkinen
|
r2520 | \brief Defines the number of rows of the model that are mapped as the data for series. | ||
Marek Rosa
|
r1507 | Minimal and default value is: -1 (count limited by the number of rows in the model) | ||
*/ | ||||
/*! | ||||
Tero Ahola
|
r1516 | \qmlproperty int VXYModelMapper::columnCount | ||
Marek Rosa
|
r1507 | Defines the number of rows of the model that are mapped as the data for series. The default value is | ||
Tero Ahola
|
r1516 | -1 (count limited by the number of rows in the model). | ||
Marek Rosa
|
r1507 | */ | ||
/*! | ||||
\fn void QVXYModelMapper::seriesReplaced() | ||||
Emitted when the series to which mapper is connected to has changed. | ||||
*/ | ||||
/*! | ||||
\fn void QVXYModelMapper::modelReplaced() | ||||
Emitted when the model to which mapper is connected to has changed. | ||||
*/ | ||||
Marek Rosa
|
r1477 | /*! | ||
\fn void QVXYModelMapper::xColumnChanged() | ||||
Emitted when the xColumn has changed. | ||||
*/ | ||||
/*! | ||||
\fn void QVXYModelMapper::yColumnChanged() | ||||
Emitted when the yColumn has changed. | ||||
*/ | ||||
Marek Rosa
|
r1507 | /*! | ||
\fn void QVXYModelMapper::firstRowChanged() | ||||
Emitted when the firstRow has changed. | ||||
*/ | ||||
/*! | ||||
\fn void QVXYModelMapper::rowCountChanged() | ||||
Emitted when the rowCount has changed. | ||||
*/ | ||||
Marek Rosa
|
r1347 | /*! | ||
Constructs a mapper object which is a child of \a parent. | ||||
*/ | ||||
Marek Rosa
|
r1252 | QVXYModelMapper::QVXYModelMapper(QObject *parent) : | ||
QXYModelMapper(parent) | ||||
{ | ||||
Marek Rosa
|
r1310 | QXYModelMapper::setOrientation(Qt::Vertical); | ||
Marek Rosa
|
r1252 | } | ||
Jani Honkonen
|
r2104 | QAbstractItemModel *QVXYModelMapper::model() const | ||
Marek Rosa
|
r1507 | { | ||
return QXYModelMapper::model(); | ||||
} | ||||
void QVXYModelMapper::setModel(QAbstractItemModel *model) | ||||
{ | ||||
if (model != QXYModelMapper::model()) { | ||||
QXYModelMapper::setModel(model); | ||||
emit modelReplaced(); | ||||
} | ||||
} | ||||
Jani Honkonen
|
r2104 | QXYSeries *QVXYModelMapper::series() const | ||
Marek Rosa
|
r1507 | { | ||
return QXYModelMapper::series(); | ||||
} | ||||
void QVXYModelMapper::setSeries(QXYSeries *series) | ||||
{ | ||||
if (series != QXYModelMapper::series()) { | ||||
QXYModelMapper::setSeries(series); | ||||
emit seriesReplaced(); | ||||
} | ||||
} | ||||
Marek Rosa
|
r1252 | int QVXYModelMapper::xColumn() const | ||
{ | ||||
return QXYModelMapper::xSection(); | ||||
} | ||||
void QVXYModelMapper::setXColumn(int xColumn) | ||||
{ | ||||
Marek Rosa
|
r1477 | if (xColumn != xSection()) { | ||
Marek Rosa
|
r1920 | QXYModelMapper::setXSection(xColumn); | ||
Marek Rosa
|
r1477 | emit xColumnChanged(); | ||
} | ||||
Marek Rosa
|
r1252 | } | ||
int QVXYModelMapper::yColumn() const | ||||
{ | ||||
return QXYModelMapper::ySection(); | ||||
} | ||||
void QVXYModelMapper::setYColumn(int yColumn) | ||||
{ | ||||
Marek Rosa
|
r1477 | if (yColumn != ySection()) { | ||
Marek Rosa
|
r1920 | QXYModelMapper::setYSection(yColumn); | ||
Marek Rosa
|
r1477 | emit yColumnChanged(); | ||
} | ||||
Marek Rosa
|
r1252 | } | ||
Marek Rosa
|
r1507 | int QVXYModelMapper::firstRow() const | ||
{ | ||||
return first(); | ||||
} | ||||
void QVXYModelMapper::setFirstRow(int firstRow) | ||||
{ | ||||
if (firstRow != first()) { | ||||
setFirst(firstRow); | ||||
emit firstRowChanged(); | ||||
} | ||||
} | ||||
int QVXYModelMapper::rowCount() const | ||||
{ | ||||
return count(); | ||||
} | ||||
void QVXYModelMapper::setRowCount(int rowCount) | ||||
{ | ||||
if (rowCount != count()) { | ||||
setCount(rowCount); | ||||
Marek Rosa
|
r1922 | emit rowCountChanged(); | ||
Marek Rosa
|
r1507 | } | ||
} | ||||
Marek Rosa
|
r1252 | #include "moc_qvxymodelmapper.cpp" | ||
QTCOMMERCIALCHART_END_NAMESPACE | ||||