summaryrefslogtreecommitdiffstats
path: root/src/piechart/qpiemodelmapper.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/piechart/qpiemodelmapper.cpp')
-rw-r--r--src/piechart/qpiemodelmapper.cpp568
1 files changed, 0 insertions, 568 deletions
diff --git a/src/piechart/qpiemodelmapper.cpp b/src/piechart/qpiemodelmapper.cpp
deleted file mode 100644
index dc68ca97..00000000
--- a/src/piechart/qpiemodelmapper.cpp
+++ /dev/null
@@ -1,568 +0,0 @@
-/****************************************************************************
-**
-** Copyright (C) 2014 Digia Plc
-** All rights reserved.
-** For any questions to Digia, please use contact form at http://qt.digia.com
-**
-** This file is part of the Qt Enterprise Charts Add-on.
-**
-** $QT_BEGIN_LICENSE$
-** Licensees holding valid Qt Enterprise licenses may use this file in
-** accordance with the Qt Enterprise License Agreement provided with the
-** 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$
-**
-****************************************************************************/
-
-#include "qpiemodelmapper.h"
-#include "qpiemodelmapper_p.h"
-#include "qpieseries.h"
-#include "qpieslice.h"
-#include <QAbstractItemModel>
-
-QTCOMMERCIALCHART_BEGIN_NAMESPACE
-
-QPieModelMapper::QPieModelMapper(QObject *parent)
- : QObject(parent),
- d_ptr(new QPieModelMapperPrivate(this))
-{
-}
-
-QAbstractItemModel *QPieModelMapper::model() const
-{
- Q_D(const QPieModelMapper);
- return d->m_model;
-}
-
-void QPieModelMapper::setModel(QAbstractItemModel *model)
-{
- if (model == 0)
- return;
-
- Q_D(QPieModelMapper);
- if (d->m_model) {
- disconnect(d->m_model, 0, d, 0);
- }
-
- d->m_model = model;
- d->initializePieFromModel();
- // connect signals from the model
- connect(d->m_model, SIGNAL(dataChanged(QModelIndex,QModelIndex)), d, SLOT(modelUpdated(QModelIndex,QModelIndex)));
- connect(d->m_model, SIGNAL(rowsInserted(QModelIndex,int,int)), d, SLOT(modelRowsAdded(QModelIndex,int,int)));
- connect(d->m_model, SIGNAL(rowsRemoved(QModelIndex,int,int)), d, SLOT(modelRowsRemoved(QModelIndex,int,int)));
- connect(d->m_model, SIGNAL(columnsInserted(QModelIndex,int,int)), d, SLOT(modelColumnsAdded(QModelIndex,int,int)));
- connect(d->m_model, SIGNAL(columnsRemoved(QModelIndex,int,int)), d, SLOT(modelColumnsRemoved(QModelIndex,int,int)));
- connect(d->m_model, SIGNAL(destroyed()), d, SLOT(handleModelDestroyed()));
-}
-
-QPieSeries *QPieModelMapper::series() const
-{
- Q_D(const QPieModelMapper);
- return d->m_series;
-}
-
-void QPieModelMapper::setSeries(QPieSeries *series)
-{
- Q_D(QPieModelMapper);
- if (d->m_series) {
- disconnect(d->m_series, 0, d, 0);
- }
-
- if (series == 0)
- return;
-
- d->m_series = series;
- d->initializePieFromModel();
- // connect the signals from the series
- connect(d->m_series, SIGNAL(added(QList<QPieSlice*>)), d, SLOT(slicesAdded(QList<QPieSlice*>)));
- connect(d->m_series, SIGNAL(removed(QList<QPieSlice*>)), d, SLOT(slicesRemoved(QList<QPieSlice*>)));
- connect(d->m_series, SIGNAL(destroyed()), d, SLOT(handleSeriesDestroyed()));
-}
-
-/*!
- Defines which row/column of the model contains the first slice value.
- Minimal and default value is: 0
-*/
-int QPieModelMapper::first() const
-{
- Q_D(const QPieModelMapper);
- return d->m_first;
-}
-
-/*!
- Sets which row/column of the model contains the \a first slice value.
- Minimal and default value is: 0
-*/
-void QPieModelMapper::setFirst(int first)
-{
- Q_D(QPieModelMapper);
- d->m_first = qMax(first, 0);
- d->initializePieFromModel();
-}
-
-/*!
- Defines the number of rows/columns of the model that are mapped as the data for QPieSeries
- Minimal and default value is: -1 (count limited by the number of rows/columns in the model)
-*/
-int QPieModelMapper::count() const
-{
- Q_D(const QPieModelMapper);
- return d->m_count;
-}
-
-/*!
- Defines the \a count of rows/columns of the model that are mapped as the data for QPieSeries
- Minimal and default value is: -1 (count limited by the number of rows/columns in the model)
-*/
-void QPieModelMapper::setCount(int count)
-{
- Q_D(QPieModelMapper);
- d->m_count = qMax(count, -1);
- d->initializePieFromModel();
-}
-
-/*!
- Returns the orientation that is used when QPieModelMapper accesses the model.
- This mean whether the consecutive values/labels of the pie are read from row (Qt::Horizontal)
- or from columns (Qt::Vertical)
-*/
-Qt::Orientation QPieModelMapper::orientation() const
-{
- Q_D(const QPieModelMapper);
- return d->m_orientation;
-}
-
-/*!
- Returns the \a orientation that is used when QPieModelMapper accesses the model.
- This mean whether the consecutive values/labels of the pie are read from row (Qt::Horizontal)
- or from columns (Qt::Vertical)
-*/
-void QPieModelMapper::setOrientation(Qt::Orientation orientation)
-{
- Q_D(QPieModelMapper);
- d->m_orientation = orientation;
- d->initializePieFromModel();
-}
-
-/*!
- Returns which section of the model is kept in sync with the values of the pie's slices
-*/
-int QPieModelMapper::valuesSection() const
-{
- Q_D(const QPieModelMapper);
- return d->m_valuesSection;
-}
-
-/*!
- Sets the model section that is kept in sync with the pie slices values.
- Parameter \a valuesSection specifies the section of the model.
-*/
-void QPieModelMapper::setValuesSection(int valuesSection)
-{
- Q_D(QPieModelMapper);
- d->m_valuesSection = qMax(-1, valuesSection);
- d->initializePieFromModel();
-}
-
-/*!
- Returns which section of the model is kept in sync with the labels of the pie's slices
-*/
-int QPieModelMapper::labelsSection() const
-{
- Q_D(const QPieModelMapper);
- return d->m_labelsSection;
-}
-
-/*!
- Sets the model section that is kept in sync with the pie slices labels.
- Parameter \a labelsSection specifies the section of the model.
-*/
-void QPieModelMapper::setLabelsSection(int labelsSection)
-{
- Q_D(QPieModelMapper);
- d->m_labelsSection = qMax(-1, labelsSection);
- d->initializePieFromModel();
-}
-
-///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
-
-QPieModelMapperPrivate::QPieModelMapperPrivate(QPieModelMapper *q) :
- QObject(q),
- m_series(0),
- m_model(0),
- m_first(0),
- m_count(-1),
- m_orientation(Qt::Vertical),
- m_valuesSection(-1),
- m_labelsSection(-1),
- m_seriesSignalsBlock(false),
- m_modelSignalsBlock(false),
- q_ptr(q)
-{
-}
-
-void QPieModelMapperPrivate::blockModelSignals(bool block)
-{
- m_modelSignalsBlock = block;
-}
-
-void QPieModelMapperPrivate::blockSeriesSignals(bool block)
-{
- m_seriesSignalsBlock = block;
-}
-
-
-QPieSlice *QPieModelMapperPrivate::pieSlice(QModelIndex index) const
-{
- if (!index.isValid())
- return 0; // index is invalid
-
- if (m_orientation == Qt::Vertical && (index.column() == m_valuesSection || index.column() == m_labelsSection)) {
- if (index.row() >= m_first && (m_count == - 1 || index.row() < m_first + m_count)) {
- if (m_model->index(index.row(), m_valuesSection).isValid() && m_model->index(index.row(), m_labelsSection).isValid())
- return m_series->slices().at(index.row() - m_first);
- else
- return 0;
- }
- } else if (m_orientation == Qt::Horizontal && (index.row() == m_valuesSection || index.row() == m_labelsSection)) {
- if (index.column() >= m_first && (m_count == - 1 || index.column() < m_first + m_count)) {
- if (m_model->index(m_valuesSection, index.column()).isValid() && m_model->index(m_labelsSection, index.column()).isValid())
- return m_series->slices().at(index.column() - m_first);
- else
- return 0;
- }
- }
- return 0; // This part of model has not been mapped to any slice
-}
-
-QModelIndex QPieModelMapperPrivate::valueModelIndex(int slicePos)
-{
- if (m_count != -1 && slicePos >= m_count)
- return QModelIndex(); // invalid
-
- if (m_orientation == Qt::Vertical)
- return m_model->index(slicePos + m_first, m_valuesSection);
- else
- return m_model->index(m_valuesSection, slicePos + m_first);
-}
-
-QModelIndex QPieModelMapperPrivate::labelModelIndex(int slicePos)
-{
- if (m_count != -1 && slicePos >= m_count)
- return QModelIndex(); // invalid
-
- if (m_orientation == Qt::Vertical)
- return m_model->index(slicePos + m_first, m_labelsSection);
- else
- return m_model->index(m_labelsSection, slicePos + m_first);
-}
-
-bool QPieModelMapperPrivate::isLabelIndex(QModelIndex index) const
-{
- if (m_orientation == Qt::Vertical && index.column() == m_labelsSection)
- return true;
- else if (m_orientation == Qt::Horizontal && index.row() == m_labelsSection)
- return true;
-
- return false;
-}
-
-bool QPieModelMapperPrivate::isValueIndex(QModelIndex index) const
-{
- if (m_orientation == Qt::Vertical && index.column() == m_valuesSection)
- return true;
- else if (m_orientation == Qt::Horizontal && index.row() == m_valuesSection)
- return true;
-
- return false;
-}
-
-void QPieModelMapperPrivate::slicesAdded(QList<QPieSlice *> slices)
-{
- if (m_seriesSignalsBlock)
- return;
-
- if (slices.count() == 0)
- return;
-
- int firstIndex = m_series->slices().indexOf(slices.at(0));
- if (firstIndex == -1)
- return;
-
- if (m_count != -1)
- m_count += slices.count();
-
- for (int i = firstIndex; i < firstIndex + slices.count(); i++) {
- m_slices.insert(i, slices.at(i - firstIndex));
- connect(slices.at(i - firstIndex), SIGNAL(labelChanged()), this, SLOT(sliceLabelChanged()));
- connect(slices.at(i - firstIndex), SIGNAL(valueChanged()), this, SLOT(sliceValueChanged()));
- }
-
- blockModelSignals();
- if (m_orientation == Qt::Vertical)
- m_model->insertRows(firstIndex + m_first, slices.count());
- else
- m_model->insertColumns(firstIndex + m_first, slices.count());
-
- for (int i = firstIndex; i < firstIndex + slices.count(); i++) {
- m_model->setData(valueModelIndex(i), slices.at(i - firstIndex)->value());
- m_model->setData(labelModelIndex(i), slices.at(i - firstIndex)->label());
- }
- blockModelSignals(false);
-}
-
-void QPieModelMapperPrivate::slicesRemoved(QList<QPieSlice *> slices)
-{
- if (m_seriesSignalsBlock)
- return;
-
- if (slices.count() == 0)
- return;
-
- int firstIndex = m_slices.indexOf(slices.at(0));
- if (firstIndex == -1)
- return;
-
- if (m_count != -1)
- m_count -= slices.count();
-
- for (int i = firstIndex + slices.count() - 1; i >= firstIndex; i--)
- m_slices.removeAt(i);
-
- blockModelSignals();
- if (m_orientation == Qt::Vertical)
- m_model->removeRows(firstIndex + m_first, slices.count());
- else
- m_model->removeColumns(firstIndex + m_first, slices.count());
- blockModelSignals(false);
-}
-
-void QPieModelMapperPrivate::sliceLabelChanged()
-{
- if (m_seriesSignalsBlock)
- return;
-
- blockModelSignals();
- QPieSlice *slice = qobject_cast<QPieSlice *>(QObject::sender());
- m_model->setData(labelModelIndex(m_series->slices().indexOf(slice)), slice->label());
- blockModelSignals(false);
-}
-
-void QPieModelMapperPrivate::sliceValueChanged()
-{
- if (m_seriesSignalsBlock)
- return;
-
- blockModelSignals();
- QPieSlice *slice = qobject_cast<QPieSlice *>(QObject::sender());
- m_model->setData(valueModelIndex(m_series->slices().indexOf(slice)), slice->value());
- blockModelSignals(false);
-}
-
-void QPieModelMapperPrivate::handleSeriesDestroyed()
-{
- m_series = 0;
-}
-
-void QPieModelMapperPrivate::modelUpdated(QModelIndex topLeft, QModelIndex bottomRight)
-{
- if (m_model == 0 || m_series == 0)
- return;
-
- if (m_modelSignalsBlock)
- return;
-
- blockSeriesSignals();
- QModelIndex index;
- QPieSlice *slice;
- for (int row = topLeft.row(); row <= bottomRight.row(); row++) {
- for (int column = topLeft.column(); column <= bottomRight.column(); column++) {
- index = topLeft.sibling(row, column);
- slice = pieSlice(index);
- if (slice) {
- if (isValueIndex(index))
- slice->setValue(m_model->data(index, Qt::DisplayRole).toReal());
- if (isLabelIndex(index))
- slice->setLabel(m_model->data(index, Qt::DisplayRole).toString());
- }
- }
- }
- blockSeriesSignals(false);
-}
-
-
-void QPieModelMapperPrivate::modelRowsAdded(QModelIndex parent, int start, int end)
-{
- Q_UNUSED(parent);
- if (m_modelSignalsBlock)
- return;
-
- blockSeriesSignals();
- if (m_orientation == Qt::Vertical)
- insertData(start, end);
- else if (start <= m_valuesSection || start <= m_labelsSection) // if the changes affect the map - reinitialize the pie
- initializePieFromModel();
- blockSeriesSignals(false);
-}
-
-void QPieModelMapperPrivate::modelRowsRemoved(QModelIndex parent, int start, int end)
-{
- Q_UNUSED(parent);
- if (m_modelSignalsBlock)
- return;
-
- blockSeriesSignals();
- if (m_orientation == Qt::Vertical)
- removeData(start, end);
- else if (start <= m_valuesSection || start <= m_labelsSection) // if the changes affect the map - reinitialize the pie
- initializePieFromModel();
- blockSeriesSignals(false);
-}
-
-void QPieModelMapperPrivate::modelColumnsAdded(QModelIndex parent, int start, int end)
-{
- Q_UNUSED(parent);
- if (m_modelSignalsBlock)
- return;
-
- blockSeriesSignals();
- if (m_orientation == Qt::Horizontal)
- insertData(start, end);
- else if (start <= m_valuesSection || start <= m_labelsSection) // if the changes affect the map - reinitialize the pie
- initializePieFromModel();
- blockSeriesSignals(false);
-}
-
-void QPieModelMapperPrivate::modelColumnsRemoved(QModelIndex parent, int start, int end)
-{
- Q_UNUSED(parent);
- if (m_modelSignalsBlock)
- return;
-
- blockSeriesSignals();
- if (m_orientation == Qt::Horizontal)
- removeData(start, end);
- else if (start <= m_valuesSection || start <= m_labelsSection) // if the changes affect the map - reinitialize the pie
- initializePieFromModel();
- blockSeriesSignals(false);
-}
-
-void QPieModelMapperPrivate::handleModelDestroyed()
-{
- m_model = 0;
-}
-
-void QPieModelMapperPrivate::insertData(int start, int end)
-{
- if (m_model == 0 || m_series == 0)
- return;
-
- if (m_count != -1 && start >= m_first + m_count) {
- return;
- } else {
- int addedCount = end - start + 1;
- if (m_count != -1 && addedCount > m_count)
- addedCount = m_count;
- int first = qMax(start, m_first);
- int last = qMin(first + addedCount - 1, m_orientation == Qt::Vertical ? m_model->rowCount() - 1 : m_model->columnCount() - 1);
- for (int i = first; i <= last; i++) {
- QModelIndex valueIndex = valueModelIndex(i - m_first);
- QModelIndex labelIndex = labelModelIndex(i - m_first);
- if (valueIndex.isValid() && labelIndex.isValid()) {
- QPieSlice *slice = new QPieSlice;
- slice->setValue(m_model->data(valueIndex, Qt::DisplayRole).toDouble());
- slice->setLabel(m_model->data(labelIndex, Qt::DisplayRole).toString());
- connect(slice, SIGNAL(labelChanged()), this, SLOT(sliceLabelChanged()));
- connect(slice, SIGNAL(valueChanged()), this, SLOT(sliceValueChanged()));
- m_series->insert(i - m_first, slice);
- m_slices.insert(i - m_first, slice);
- }
- }
-
- // remove excess of slices (abouve m_count)
- if (m_count != -1 && m_series->slices().size() > m_count)
- for (int i = m_series->slices().size() - 1; i >= m_count; i--) {
- m_series->remove(m_series->slices().at(i));
- m_slices.removeAt(i);
- }
- }
-}
-
-void QPieModelMapperPrivate::removeData(int start, int end)
-{
- if (m_model == 0 || m_series == 0)
- return;
-
- int removedCount = end - start + 1;
- if (m_count != -1 && start >= m_first + m_count) {
- return;
- } else {
- int toRemove = qMin(m_series->slices().size(), removedCount); // first find how many items can actually be removed
- int first = qMax(start, m_first); // get the index of the first item that will be removed.
- int last = qMin(first + toRemove - 1, m_series->slices().size() + m_first - 1); // get the index of the last item that will be removed.
- for (int i = last; i >= first; i--) {
- m_series->remove(m_series->slices().at(i - m_first));
- m_slices.removeAt(i - m_first);
- }
-
- if (m_count != -1) {
- int itemsAvailable; // check how many are available to be added
- if (m_orientation == Qt::Vertical)
- itemsAvailable = m_model->rowCount() - m_first - m_series->slices().size();
- else
- itemsAvailable = m_model->columnCount() - m_first - m_series->slices().size();
- int toBeAdded = qMin(itemsAvailable, m_count - m_series->slices().size()); // add not more items than there is space left to be filled.
- int currentSize = m_series->slices().size();
- if (toBeAdded > 0)
- for (int i = m_series->slices().size(); i < currentSize + toBeAdded; i++) {
- QModelIndex valueIndex = valueModelIndex(i - m_first);
- QModelIndex labelIndex = labelModelIndex(i - m_first);
- if (valueIndex.isValid() && labelIndex.isValid()) {
- QPieSlice *slice = new QPieSlice;
- slice->setValue(m_model->data(valueIndex, Qt::DisplayRole).toDouble());
- slice->setLabel(m_model->data(labelIndex, Qt::DisplayRole).toString());
- m_series->insert(i, slice);
- m_slices.insert(i, slice);
- }
- }
- }
- }
-}
-
-void QPieModelMapperPrivate::initializePieFromModel()
-{
- if (m_model == 0 || m_series == 0)
- return;
-
- blockSeriesSignals();
- // clear current content
- m_series->clear();
- m_slices.clear();
-
- // create the initial slices set
- int slicePos = 0;
- QModelIndex valueIndex = valueModelIndex(slicePos);
- QModelIndex labelIndex = labelModelIndex(slicePos);
- while (valueIndex.isValid() && labelIndex.isValid()) {
- QPieSlice *slice = new QPieSlice;
- slice->setLabel(m_model->data(labelIndex, Qt::DisplayRole).toString());
- slice->setValue(m_model->data(valueIndex, Qt::DisplayRole).toDouble());
- connect(slice, SIGNAL(labelChanged()), this, SLOT(sliceLabelChanged()));
- connect(slice, SIGNAL(valueChanged()), this, SLOT(sliceValueChanged()));
- m_series->append(slice);
- m_slices.append(slice);
- slicePos++;
- valueIndex = valueModelIndex(slicePos);
- labelIndex = labelModelIndex(slicePos);
- }
- blockSeriesSignals(false);
-}
-
-#include "moc_qpiemodelmapper_p.cpp"
-#include "moc_qpiemodelmapper.cpp"
-
-QTCOMMERCIALCHART_END_NAMESPACE