@@ -0,0 +1,58 | |||
|
1 | #ifndef QPIEMODELMAPPER_P_H | |
|
2 | #define QPIEMODELMAPPER_P_H | |
|
3 | ||
|
4 | #include "qpiemodelmapper.h" | |
|
5 | #include <QObject> | |
|
6 | ||
|
7 | class QModelIndex; | |
|
8 | class QAbstractItemModel; | |
|
9 | ||
|
10 | QTCOMMERCIALCHART_BEGIN_NAMESPACE | |
|
11 | ||
|
12 | class QPieModelMapper; | |
|
13 | class QPieSeries; | |
|
14 | ||
|
15 | class QPieModelMapperPrivate : public QObject | |
|
16 | { | |
|
17 | Q_OBJECT | |
|
18 | ||
|
19 | public: | |
|
20 | QPieModelMapperPrivate(QPieModelMapper *q); | |
|
21 | ||
|
22 | public Q_SLOTS: | |
|
23 | // for the model | |
|
24 | void modelUpdated(QModelIndex topLeft, QModelIndex bottomRight); | |
|
25 | // void modelRowsAdded(QModelIndex parent, int start, int end); | |
|
26 | // void modelRowsRemoved(QModelIndex parent, int start, int end); | |
|
27 | // void modelColumnsAdded(QModelIndex parent, int start, int end); | |
|
28 | // void modelColumnsRemoved(QModelIndex parent, int start, int end); | |
|
29 | ||
|
30 | // for the series | |
|
31 | void slicesAdded(); | |
|
32 | void slicesRemoved(); | |
|
33 | void sliceChanged(); | |
|
34 | ||
|
35 | private: | |
|
36 | void setModel(QAbstractItemModel *model); | |
|
37 | ||
|
38 | private: | |
|
39 | int getSliceIndex(); | |
|
40 | ||
|
41 | private: | |
|
42 | int m_first; | |
|
43 | int m_count; | |
|
44 | Qt::Orientation m_orientation; | |
|
45 | int m_mapValues; | |
|
46 | int m_mapLabels; | |
|
47 | ||
|
48 | private: | |
|
49 | QPieSeries *m_series; | |
|
50 | QAbstractItemModel *m_model; | |
|
51 | QPieModelMapper *q_ptr; | |
|
52 | Q_DECLARE_PUBLIC(QPieModelMapper) | |
|
53 | friend class QPieSeriesPrivate; | |
|
54 | }; | |
|
55 | ||
|
56 | QTCOMMERCIALCHART_END_NAMESPACE | |
|
57 | ||
|
58 | #endif // QPIEMODELMAPPER_P_H |
@@ -12,7 +12,8 PRIVATE_HEADERS += \ | |||
|
12 | 12 | $$PWD/pieslicedata_p.h \ |
|
13 | 13 | $$PWD/piechartitem_p.h \ |
|
14 | 14 | $$PWD/piesliceitem_p.h \ |
|
15 | $$PWD/qpieseries_p.h | |
|
15 | $$PWD/qpieseries_p.h \ | |
|
16 | $$PWD/qpiemodelmapper_p.h | |
|
16 | 17 | |
|
17 | 18 | PUBLIC_HEADERS += \ |
|
18 | 19 | $$PWD/qpieseries.h \ |
@@ -1,82 +1,319 | |||
|
1 | #include "qpiemodelmapper_p.h" | |
|
1 | 2 | #include "qpiemodelmapper.h" |
|
3 | #include "qpieseries.h" | |
|
4 | #include "qpieslice.h" | |
|
5 | #include <QAbstractItemModel> | |
|
2 | 6 | |
|
3 | 7 | QTCOMMERCIALCHART_BEGIN_NAMESPACE |
|
4 | 8 | |
|
5 | 9 | QPieModelMapper::QPieModelMapper(QObject *parent) : |
|
6 | 10 | QObject(parent), |
|
7 | m_first(0), | |
|
8 | m_count(-1), | |
|
9 | m_orientation(Qt::Vertical), | |
|
10 | m_mapValues(-1), | |
|
11 | m_mapLabels(-1) | |
|
11 | d_ptr(new QPieModelMapperPrivate(this)) | |
|
12 | 12 | { |
|
13 | 13 | } |
|
14 | 14 | |
|
15 | 15 | int QPieModelMapper::first() const |
|
16 | 16 | { |
|
17 | return m_first; | |
|
17 | Q_D(const QPieModelMapper); | |
|
18 | return d->m_first; | |
|
18 | 19 | } |
|
19 | 20 | |
|
20 | 21 | void QPieModelMapper::setFirst(int first) |
|
21 | 22 | { |
|
22 | m_first = qMax(first, 0); | |
|
23 | emit updated(); | |
|
23 | Q_D(QPieModelMapper); | |
|
24 | d->m_first = qMax(first, 0); | |
|
25 | // emit updated(); | |
|
24 | 26 | } |
|
25 | 27 | |
|
26 | 28 | int QPieModelMapper::count() const |
|
27 | 29 | { |
|
28 | return m_count; | |
|
30 | Q_D(const QPieModelMapper); | |
|
31 | return d->m_count; | |
|
29 | 32 | } |
|
30 | 33 | |
|
31 | 34 | void QPieModelMapper::setCount(int count) |
|
32 | 35 | { |
|
33 | m_count = qMax(count, -1); | |
|
34 | emit updated(); | |
|
36 | Q_D(QPieModelMapper); | |
|
37 | d->m_count = qMax(count, -1); | |
|
38 | // emit updated(); | |
|
35 | 39 | } |
|
36 | 40 | |
|
37 | 41 | Qt::Orientation QPieModelMapper::orientation() const |
|
38 | 42 | { |
|
39 | return m_orientation; | |
|
43 | Q_D(const QPieModelMapper); | |
|
44 | return d->m_orientation; | |
|
40 | 45 | } |
|
41 | 46 | |
|
42 | 47 | void QPieModelMapper::setOrientation(Qt::Orientation orientation) |
|
43 | 48 | { |
|
44 | m_orientation = orientation; | |
|
45 | emit updated(); | |
|
49 | Q_D(QPieModelMapper); | |
|
50 | d->m_orientation = orientation; | |
|
51 | // emit updated(); | |
|
46 | 52 | } |
|
47 | 53 | |
|
48 | 54 | int QPieModelMapper::mapValues() const |
|
49 | 55 | { |
|
50 | return m_mapValues; | |
|
56 | Q_D(const QPieModelMapper); | |
|
57 | return d->m_mapValues; | |
|
51 | 58 | } |
|
52 | 59 | |
|
53 | 60 | void QPieModelMapper::setMapValues(int mapValues) |
|
54 | 61 | { |
|
55 | m_mapValues = mapValues; | |
|
56 | emit updated(); | |
|
62 | Q_D(QPieModelMapper); | |
|
63 | d->m_mapValues = mapValues; | |
|
64 | // emit updated(); | |
|
57 | 65 | } |
|
58 | 66 | |
|
59 | 67 | int QPieModelMapper::mapLabels() const |
|
60 | 68 | { |
|
61 | return m_mapLabels; | |
|
69 | Q_D(const QPieModelMapper); | |
|
70 | return d->m_mapLabels; | |
|
62 | 71 | } |
|
63 | 72 | |
|
64 | 73 | void QPieModelMapper::setMapLabels(int mapLabels) |
|
65 | 74 | { |
|
66 | m_mapLabels = mapLabels; | |
|
67 | emit updated(); | |
|
75 | Q_D(QPieModelMapper); | |
|
76 | d->m_mapLabels = mapLabels; | |
|
77 | // emit updated(); | |
|
68 | 78 | } |
|
69 | 79 | |
|
70 | 80 | void QPieModelMapper::reset() |
|
71 | 81 | { |
|
82 | Q_D(QPieModelMapper); | |
|
83 | d->m_first = 0; | |
|
84 | d->m_count = -1; | |
|
85 | d->m_orientation = Qt::Vertical; | |
|
86 | d->m_mapValues = -1; | |
|
87 | d->m_mapLabels = -1; | |
|
88 | // emit updated(); | |
|
89 | } | |
|
90 | ||
|
91 | /////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////// | |
|
92 | ||
|
93 | QPieModelMapperPrivate::QPieModelMapperPrivate(QPieModelMapper *q) : | |
|
94 | q_ptr(q) | |
|
95 | { | |
|
72 | 96 | m_first = 0; |
|
73 | 97 | m_count = -1; |
|
74 | 98 | m_orientation = Qt::Vertical; |
|
75 | 99 | m_mapValues = -1; |
|
76 | 100 | m_mapLabels = -1; |
|
77 | emit updated(); | |
|
78 | 101 | } |
|
79 | 102 | |
|
103 | int QPieModelMapperPrivate::getSliceIndex() | |
|
104 | { | |
|
105 | ||
|
106 | // invalid | |
|
107 | return -1; | |
|
108 | } | |
|
109 | ||
|
110 | void QPieModelMapperPrivate::setModel(QAbstractItemModel *model) | |
|
111 | { | |
|
112 | if (model == 0) | |
|
113 | return; | |
|
114 | ||
|
115 | if(m_model) | |
|
116 | { | |
|
117 | // disconnect signals from old model | |
|
118 | disconnect(m_model, 0, this, 0); | |
|
119 | } | |
|
120 | ||
|
121 | m_model = model; | |
|
122 | // connect signals from the model | |
|
123 | connect(m_model, SIGNAL(dataChanged(QModelIndex,QModelIndex)), this, SLOT(modelUpdated(QModelIndex,QModelIndex))); | |
|
124 | connect(m_model, SIGNAL(rowsInserted(QModelIndex,int,int)), this, SLOT(modelRowsAdded(QModelIndex,int,int))); | |
|
125 | connect(m_model, SIGNAL(rowsRemoved(QModelIndex,int,int)), this, SLOT(modelRowsRemoved(QModelIndex,int,int))); | |
|
126 | connect(m_model, SIGNAL(columnsInserted(QModelIndex,int,int)), this, SLOT(modelColumnsAdded(QModelIndex,int,int))); | |
|
127 | connect(m_model, SIGNAL(columnsRemoved(QModelIndex,int,int)), this, SLOT(modelColumnsRemoved(QModelIndex,int,int))); | |
|
128 | } | |
|
129 | ||
|
130 | void QPieModelMapperPrivate::slicesAdded() | |
|
131 | { | |
|
132 | // | |
|
133 | } | |
|
134 | ||
|
135 | void QPieModelMapperPrivate::slicesRemoved() | |
|
136 | { | |
|
137 | // | |
|
138 | } | |
|
139 | ||
|
140 | void QPieModelMapperPrivate::sliceChanged() | |
|
141 | { | |
|
142 | // | |
|
143 | } | |
|
144 | ||
|
145 | void QPieModelMapperPrivate::modelUpdated(QModelIndex topLeft, QModelIndex bottomRight) | |
|
146 | { | |
|
147 | for (int row = topLeft.row(); row <= bottomRight.row(); row++) { | |
|
148 | for (int column = topLeft.column(); column <= bottomRight.column(); column++) { | |
|
149 | if (m_orientation == Qt::Vertical) | |
|
150 | { | |
|
151 | if ( topLeft.row() >= m_first && (m_count == - 1 || topLeft.row() < m_first + m_count)) { | |
|
152 | if (topLeft.column() == m_mapValues) | |
|
153 | m_series->slices().at(topLeft.row() - m_first)->setValue(m_model->data(topLeft, Qt::DisplayRole).toDouble()); | |
|
154 | if (topLeft.column() == m_mapLabels) | |
|
155 | m_series->slices().at(topLeft.row() - m_first)->setLabel(m_model->data(topLeft, Qt::DisplayRole).toString()); | |
|
156 | } | |
|
157 | } | |
|
158 | else | |
|
159 | { | |
|
160 | if (topLeft.column() >= m_first && (m_count == - 1 || topLeft.column() < m_first + m_count)) { | |
|
161 | if (topLeft.row() == m_mapValues) | |
|
162 | m_series->slices().at(topLeft.column() - m_first)->setValue(m_model->data(topLeft, Qt::DisplayRole).toDouble()); | |
|
163 | if (topLeft.row() == m_mapLabels) | |
|
164 | m_series->slices().at(topLeft.column() - m_first)->setLabel(m_model->data(topLeft, Qt::DisplayRole).toString()); | |
|
165 | } | |
|
166 | } | |
|
167 | } | |
|
168 | } | |
|
169 | } | |
|
170 | ||
|
171 | ||
|
172 | //void QPieModelMapperPrivate::modelRowsAdded(QModelIndex parent, int start, int end) | |
|
173 | //{ | |
|
174 | // Q_UNUSED(parent); | |
|
175 | // if (m_mapper->orientation() == Qt::Vertical) | |
|
176 | // insertData(start, end); | |
|
177 | // else if (start <= m_mapValues || start <= m_mapLabels) // if the changes affect the map - reinitialize the pie | |
|
178 | // initializePieFromModel(); | |
|
179 | //} | |
|
180 | ||
|
181 | //void QPieModelMapperPrivate::modelRowsRemoved(QModelIndex parent, int start, int end) | |
|
182 | //{ | |
|
183 | // Q_UNUSED(parent); | |
|
184 | // if (m_mapper->orientation() == Qt::Vertical) | |
|
185 | // removeData(start, end); | |
|
186 | // else if (start <= m_mapValues || start <= m_mapLabels) // if the changes affect the map - reinitialize the pie | |
|
187 | // initializePieFromModel(); | |
|
188 | //} | |
|
189 | ||
|
190 | //void QPieModelMapperPrivate::modelColumnsAdded(QModelIndex parent, int start, int end) | |
|
191 | //{ | |
|
192 | // Q_UNUSED(parent); | |
|
193 | // if (m_mapper->orientation() == Qt::Horizontal) | |
|
194 | // insertData(start, end); | |
|
195 | // else if (start <= m_mapValues || start <= m_mapLabels) // if the changes affect the map - reinitialize the pie | |
|
196 | // initializePieFromModel(); | |
|
197 | //} | |
|
198 | ||
|
199 | //void QPieModelMapperPrivate::modelColumnsRemoved(QModelIndex parent, int start, int end) | |
|
200 | //{ | |
|
201 | // Q_UNUSED(parent); | |
|
202 | // if (m_mapper->orientation() == Qt::Horizontal) | |
|
203 | // removeData(start, end); | |
|
204 | // else if (start <= m_mapValues || start <= m_mapLabels) // if the changes affect the map - reinitialize the pie | |
|
205 | // initializePieFromModel(); | |
|
206 | //} | |
|
207 | ||
|
208 | //void QPieModelMapperPrivate::insertData(int start, int end) | |
|
209 | //{ | |
|
210 | // Q_Q(QPieSeries); | |
|
211 | // if (m_count != -1 && start >= m_first + m_count) { | |
|
212 | // return; | |
|
213 | // } else { | |
|
214 | // int addedCount = end - start + 1; | |
|
215 | // if (m_count != -1 && addedCount > m_count) | |
|
216 | // addedCount = m_count; | |
|
217 | // int first = qMax(start, m_first); | |
|
218 | // int last = qMin(first + addedCount - 1, m_mapper->orientation() == Qt::Vertical ? m_model->rowCount() - 1 : m_model->columnCount() - 1); | |
|
219 | // for (int i = first; i <= last; i++) { | |
|
220 | // QPieSlice *slice = new QPieSlice; | |
|
221 | // if (m_mapper->orientation() == Qt::Vertical) { | |
|
222 | // slice->setValue(m_model->data(m_model->index(i, m_mapValues), Qt::DisplayRole).toDouble()); | |
|
223 | // slice->setLabel(m_model->data(m_model->index(i, m_mapLabels), Qt::DisplayRole).toString()); | |
|
224 | // } else { | |
|
225 | // slice->setValue(m_model->data(m_model->index(m_mapValues, i), Qt::DisplayRole).toDouble()); | |
|
226 | // slice->setLabel(m_model->data(m_model->index(m_mapLabels, i), Qt::DisplayRole).toString()); | |
|
227 | // } | |
|
228 | // slice->setLabelVisible(); | |
|
229 | // q->insert(i - m_first, slice); | |
|
230 | // } | |
|
231 | // if (m_count != -1 && m_series->slices().size() > m_count) | |
|
232 | // for (int i = m_series->slices().size() - 1; i >= m_count; i--) | |
|
233 | // q->remove(q->slices().at(i)); | |
|
234 | // } | |
|
235 | //} | |
|
236 | ||
|
237 | //void QPieModelMapperPrivate::removeData(int start, int end) | |
|
238 | //{ | |
|
239 | // Q_Q(QPieSeries); | |
|
240 | // int removedCount = end - start + 1; | |
|
241 | // if (m_count != -1 && start >= m_first + m_count) { | |
|
242 | // return; | |
|
243 | // } else { | |
|
244 | // int toRemove = qMin(m_series->slices().size(), removedCount); // first find how many items can actually be removed | |
|
245 | // int first = qMax(start, m_first); // get the index of the first item that will be removed. | |
|
246 | // int last = qMin(first + toRemove - 1, m_series->slices().size() + m_first - 1); // get the index of the last item that will be removed. | |
|
247 | // for (int i = last; i >= first; i--) | |
|
248 | // q->remove(q->slices().at(i - m_first)); | |
|
249 | ||
|
250 | // if (m_count != -1) { | |
|
251 | // int itemsAvailable; // check how many are available to be added | |
|
252 | // if (m_mapper->orientation() == Qt::Vertical) | |
|
253 | // itemsAvailable = m_model->rowCount() - m_first - m_series->slices().size(); | |
|
254 | // else | |
|
255 | // itemsAvailable = m_model->columnCount() - m_first - m_series->slices().size(); | |
|
256 | // int toBeAdded = qMin(itemsAvailable, m_count - m_series->slices().size()); // add not more items than there is space left to be filled. | |
|
257 | // int currentSize = m_series->slices().size(); | |
|
258 | // if (toBeAdded > 0) | |
|
259 | // for (int i = m_series->slices().size(); i < currentSize + toBeAdded; i++) { | |
|
260 | // QPieSlice *slice = new QPieSlice; | |
|
261 | // if (m_mapper->orientation() == Qt::Vertical) { | |
|
262 | // slice->setValue(m_model->data(m_model->index(i + m_first, m_mapValues), Qt::DisplayRole).toDouble()); | |
|
263 | // slice->setLabel(m_model->data(m_model->index(i + m_first, m_mapLabels), Qt::DisplayRole).toString()); | |
|
264 | // } else { | |
|
265 | // slice->setValue(m_model->data(m_model->index(m_mapValues, i + m_first), Qt::DisplayRole).toDouble()); | |
|
266 | // slice->setLabel(m_model->data(m_model->index(m_mapLabels, i + m_first), Qt::DisplayRole).toString()); | |
|
267 | // } | |
|
268 | // slice->setLabelVisible(); | |
|
269 | // q->insert(i, slice); | |
|
270 | // } | |
|
271 | // } | |
|
272 | // } | |
|
273 | //} | |
|
274 | ||
|
275 | //void QPieModelMapperPrivate::initializePieFromModel() | |
|
276 | //{ | |
|
277 | // Q_Q(QPieSeries); | |
|
278 | ||
|
279 | // // clear current content | |
|
280 | // q->clear(); | |
|
281 | ||
|
282 | // if (m_model == 0 || m_mapper == 0) | |
|
283 | // return; | |
|
284 | ||
|
285 | // // check if mappings are set | |
|
286 | // if (m_mapValues == -1 || m_mapLabels == -1) | |
|
287 | // return; | |
|
288 | ||
|
289 | // // create the initial slices set | |
|
290 | // if (m_mapper->orientation() == Qt::Vertical) { | |
|
291 | // if (m_mapValues >= m_model->columnCount() || m_mapLabels >= m_model->columnCount()) | |
|
292 | // return; // mapped columns are not existing | |
|
293 | ||
|
294 | // int sliceCount = 0; | |
|
295 | // if(m_count == -1) | |
|
296 | // sliceCount = m_model->rowCount() - m_first; | |
|
297 | // else | |
|
298 | // sliceCount = qMin(m_count, m_model->rowCount() - m_first); | |
|
299 | // for (int i = m_first; i < m_first + sliceCount; i++) | |
|
300 | // q->append(m_model->data(m_model->index(i, m_mapValues), Qt::DisplayRole).toDouble(), m_model->data(m_model->index(i, m_mapLabels), Qt::DisplayRole).toString()); | |
|
301 | // } else { | |
|
302 | // if (m_mapValues >= m_model->rowCount() || m_mapLabels >= m_model->rowCount()) | |
|
303 | // return; // mapped columns are not existing | |
|
304 | ||
|
305 | // int sliceCount = 0; | |
|
306 | // if(m_count == -1) | |
|
307 | // sliceCount = m_model->columnCount() - m_first; | |
|
308 | // else | |
|
309 | // sliceCount = qMin(m_count, m_model->columnCount() - m_first); | |
|
310 | // for (int i = m_first; i < m_first + sliceCount; i++) | |
|
311 | // q->append(m_model->data(m_model->index(m_mapValues, i), Qt::DisplayRole).toDouble(), m_model->data(m_model->index(m_mapLabels, i), Qt::DisplayRole).toString()); | |
|
312 | // } | |
|
313 | // q->setLabelsVisible(true); | |
|
314 | //} | |
|
315 | ||
|
316 | #include "moc_qpiemodelmapper_p.cpp" | |
|
80 | 317 | #include "moc_qpiemodelmapper.cpp" |
|
81 | 318 | |
|
82 | 319 | QTCOMMERCIALCHART_END_NAMESPACE |
@@ -6,6 +6,8 | |||
|
6 | 6 | |
|
7 | 7 | QTCOMMERCIALCHART_BEGIN_NAMESPACE |
|
8 | 8 | |
|
9 | class QPieModelMapperPrivate; | |
|
10 | ||
|
9 | 11 | class QTCOMMERCIALCHART_EXPORT QPieModelMapper : public QObject |
|
10 | 12 | { |
|
11 | 13 | Q_OBJECT |
@@ -17,7 +19,10 class QTCOMMERCIALCHART_EXPORT QPieModelMapper : public QObject | |||
|
17 | 19 | Q_ENUMS(Qt::Orientation) |
|
18 | 20 | |
|
19 | 21 | public: |
|
20 |
|
|
|
22 | QPieModelMapper(QObject *parent = 0); | |
|
23 | ||
|
24 | // QAbstractItemModel* model() const; | |
|
25 | // void setModel(QAbstractItemModel *model); | |
|
21 | 26 | |
|
22 | 27 | int first() const; |
|
23 | 28 | void setFirst(int first); |
@@ -36,16 +41,10 public: | |||
|
36 | 41 | |
|
37 | 42 | void reset(); |
|
38 | 43 | |
|
39 | Q_SIGNALS: | |
|
40 | void updated(); | |
|
41 | ||
|
42 | 44 | private: |
|
43 | int m_first; | |
|
44 | int m_count; | |
|
45 | Qt::Orientation m_orientation; | |
|
46 | int m_mapValues; | |
|
47 | int m_mapLabels; | |
|
48 | ||
|
45 | QScopedPointer<QPieModelMapperPrivate> d_ptr; | |
|
46 | Q_DECLARE_PRIVATE(QPieModelMapper) | |
|
47 | friend class QPieSeriesPrivate; | |
|
49 | 48 | }; |
|
50 | 49 | |
|
51 | 50 | QTCOMMERCIALCHART_END_NAMESPACE |
@@ -28,6 +28,7 | |||
|
28 | 28 | #include "legendmarker_p.h" |
|
29 | 29 | #include <QAbstractItemModel> |
|
30 | 30 | #include "qpiemodelmapper.h" |
|
31 | #include "qpiemodelmapper_p.h" | |
|
31 | 32 | |
|
32 | 33 | QTCOMMERCIALCHART_BEGIN_NAMESPACE |
|
33 | 34 | |
@@ -469,30 +470,31 qreal QPieSeries::sum() const | |||
|
469 | 470 | void QPieSeries::setModel(QAbstractItemModel* model) |
|
470 | 471 | { |
|
471 | 472 | Q_D(QPieSeries); |
|
472 | // disconnect signals from old model | |
|
473 | if(d->m_model) | |
|
474 | { | |
|
475 | disconnect(d->m_model, 0, this, 0); | |
|
476 | } | |
|
477 | ||
|
478 | // set new model | |
|
479 | if(model) | |
|
480 | { | |
|
481 | d->m_model = model; | |
|
482 | // connect signals from the model | |
|
483 | connect(d->m_model, SIGNAL(dataChanged(QModelIndex,QModelIndex)), d, SLOT(modelUpdated(QModelIndex,QModelIndex))); | |
|
484 |
connect(d->m_model, SIGNAL( |
|
|
485 |
connect(d->m_model, SIGNAL(rows |
|
|
486 |
connect(d->m_model, SIGNAL( |
|
|
487 |
connect(d->m_model, SIGNAL(columns |
|
|
488 | ||
|
489 | if (d->m_mapper) | |
|
490 | d->initializePieFromModel(); | |
|
491 | } | |
|
492 | else | |
|
493 | { | |
|
494 | d->m_model = 0; | |
|
495 | } | |
|
473 | d->setModel(model); | |
|
474 | // // disconnect signals from old model | |
|
475 | // if(d->m_model) | |
|
476 | // { | |
|
477 | // disconnect(d->m_model, 0, this, 0); | |
|
478 | // } | |
|
479 | ||
|
480 | // // set new model | |
|
481 | // if(model) | |
|
482 | // { | |
|
483 | // d->m_model = model; | |
|
484 | // // connect signals from the model | |
|
485 | //// connect(d->m_model, SIGNAL(dataChanged(QModelIndex,QModelIndex)), d, SLOT(modelUpdated(QModelIndex,QModelIndex))); | |
|
486 | //// connect(d->m_model, SIGNAL(rowsInserted(QModelIndex,int,int)), d, SLOT(modelRowsAdded(QModelIndex,int,int))); | |
|
487 | //// connect(d->m_model, SIGNAL(rowsRemoved(QModelIndex,int,int)), d, SLOT(modelRowsRemoved(QModelIndex,int,int))); | |
|
488 | //// connect(d->m_model, SIGNAL(columnsInserted(QModelIndex,int,int)), d, SLOT(modelColumnsAdded(QModelIndex,int,int))); | |
|
489 | //// connect(d->m_model, SIGNAL(columnsRemoved(QModelIndex,int,int)), d, SLOT(modelColumnsRemoved(QModelIndex,int,int))); | |
|
490 | ||
|
491 | //// if (d->m_mapper) | |
|
492 | //// d->initializePieFromModel(); | |
|
493 | // } | |
|
494 | // else | |
|
495 | // { | |
|
496 | // d->m_model = 0; | |
|
497 | // } | |
|
496 | 498 | } |
|
497 | 499 | |
|
498 | 500 | void QPieSeries::setModelMapper(QPieModelMapper *mapper) |
@@ -506,10 +508,10 void QPieSeries::setModelMapper(QPieModelMapper *mapper) | |||
|
506 | 508 | if (mapper) { |
|
507 | 509 | d->m_mapper = mapper; |
|
508 | 510 | // connect the signal from the mapper |
|
509 | connect(d->m_mapper, SIGNAL(updated()), d, SLOT(initializePieFromModel())); | |
|
511 | // connect(d->m_mapper, SIGNAL(updated()), d, SLOT(initializePieFromModel())); | |
|
510 | 512 | |
|
511 | if (d->m_model) | |
|
512 | d->initializePieFromModel(); | |
|
513 | // if (d->m_model) | |
|
514 | // d->initializePieFromModel(); | |
|
513 | 515 | } else { |
|
514 | 516 | d->m_mapper = 0; |
|
515 | 517 | } |
@@ -532,6 +534,7 QPieSeriesPrivate::QPieSeriesPrivate(QPieSeries *parent) : | |||
|
532 | 534 | m_pieStartAngle(0), |
|
533 | 535 | m_pieEndAngle(360), |
|
534 | 536 | m_sum(0), |
|
537 | m_model(0), | |
|
535 | 538 | m_mapper(0) |
|
536 | 539 | { |
|
537 | 540 | |
@@ -608,191 +611,6 void QPieSeriesPrivate::sliceHovered(bool state) | |||
|
608 | 611 | emit q->hovered(slice, state); |
|
609 | 612 | } |
|
610 | 613 | |
|
611 | void QPieSeriesPrivate::modelUpdated(QModelIndex topLeft, QModelIndex bottomRight) | |
|
612 | { | |
|
613 | if (m_mapper) { | |
|
614 | for (int row = topLeft.row(); row <= bottomRight.row(); row++) { | |
|
615 | for (int column = topLeft.column(); column <= bottomRight.column(); column++) { | |
|
616 | if (m_mapper->orientation() == Qt::Vertical) | |
|
617 | { | |
|
618 | if ( topLeft.row() >= m_mapper->first() && (m_mapper->count() == - 1 || topLeft.row() < m_mapper->first() + m_mapper->count())) { | |
|
619 | if (topLeft.column() == m_mapper->mapValues()) | |
|
620 | m_slices.at(topLeft.row() - m_mapper->first())->setValue(m_model->data(topLeft, Qt::DisplayRole).toDouble()); | |
|
621 | if (topLeft.column() == m_mapper->mapLabels()) | |
|
622 | m_slices.at(topLeft.row() - m_mapper->first())->setLabel(m_model->data(topLeft, Qt::DisplayRole).toString()); | |
|
623 | } | |
|
624 | } | |
|
625 | else | |
|
626 | { | |
|
627 | if (topLeft.column() >= m_mapper->first() && (m_mapper->count() == - 1 || topLeft.column() < m_mapper->first() + m_mapper->count())) { | |
|
628 | if (topLeft.row() == m_mapper->mapValues()) | |
|
629 | m_slices.at(topLeft.column() - m_mapper->first())->setValue(m_model->data(topLeft, Qt::DisplayRole).toDouble()); | |
|
630 | if (topLeft.row() == m_mapper->mapLabels()) | |
|
631 | m_slices.at(topLeft.column() - m_mapper->first())->setLabel(m_model->data(topLeft, Qt::DisplayRole).toString()); | |
|
632 | } | |
|
633 | } | |
|
634 | } | |
|
635 | } | |
|
636 | } | |
|
637 | } | |
|
638 | ||
|
639 | ||
|
640 | void QPieSeriesPrivate::modelRowsAdded(QModelIndex parent, int start, int end) | |
|
641 | { | |
|
642 | Q_UNUSED(parent); | |
|
643 | if (m_mapper) { | |
|
644 | if (m_mapper->orientation() == Qt::Vertical) | |
|
645 | insertData(start, end); | |
|
646 | else if (start <= m_mapper->mapValues() || start <= m_mapper->mapLabels()) // if the changes affect the map - reinitialize the pie | |
|
647 | initializePieFromModel(); | |
|
648 | } | |
|
649 | } | |
|
650 | ||
|
651 | void QPieSeriesPrivate::modelRowsRemoved(QModelIndex parent, int start, int end) | |
|
652 | { | |
|
653 | Q_UNUSED(parent); | |
|
654 | if (m_mapper) { | |
|
655 | if (m_mapper->orientation() == Qt::Vertical) | |
|
656 | removeData(start, end); | |
|
657 | else if (start <= m_mapper->mapValues() || start <= m_mapper->mapLabels()) // if the changes affect the map - reinitialize the pie | |
|
658 | initializePieFromModel(); | |
|
659 | } | |
|
660 | } | |
|
661 | ||
|
662 | void QPieSeriesPrivate::modelColumnsAdded(QModelIndex parent, int start, int end) | |
|
663 | { | |
|
664 | Q_UNUSED(parent); | |
|
665 | if (m_mapper) { | |
|
666 | if (m_mapper->orientation() == Qt::Horizontal) | |
|
667 | insertData(start, end); | |
|
668 | else if (start <= m_mapper->mapValues() || start <= m_mapper->mapLabels()) // if the changes affect the map - reinitialize the pie | |
|
669 | initializePieFromModel(); | |
|
670 | } | |
|
671 | } | |
|
672 | ||
|
673 | void QPieSeriesPrivate::modelColumnsRemoved(QModelIndex parent, int start, int end) | |
|
674 | { | |
|
675 | Q_UNUSED(parent); | |
|
676 | if (m_mapper) { | |
|
677 | if (m_mapper->orientation() == Qt::Horizontal) | |
|
678 | removeData(start, end); | |
|
679 | else if (start <= m_mapper->mapValues() || start <= m_mapper->mapLabels()) // if the changes affect the map - reinitialize the pie | |
|
680 | initializePieFromModel(); | |
|
681 | } | |
|
682 | } | |
|
683 | ||
|
684 | void QPieSeriesPrivate::insertData(int start, int end) | |
|
685 | { | |
|
686 | Q_Q(QPieSeries); | |
|
687 | if (m_mapper) { | |
|
688 | if (m_mapper->count() != -1 && start >= m_mapper->first() + m_mapper->count()) { | |
|
689 | return; | |
|
690 | } else { | |
|
691 | int addedCount = end - start + 1; | |
|
692 | if (m_mapper->count() != -1 && addedCount > m_mapper->count()) | |
|
693 | addedCount = m_mapper->count(); | |
|
694 | int first = qMax(start, m_mapper->first()); | |
|
695 | int last = qMin(first + addedCount - 1, m_mapper->orientation() == Qt::Vertical ? m_model->rowCount() - 1 : m_model->columnCount() - 1); | |
|
696 | for (int i = first; i <= last; i++) { | |
|
697 | QPieSlice *slice = new QPieSlice; | |
|
698 | if (m_mapper->orientation() == Qt::Vertical) { | |
|
699 | slice->setValue(m_model->data(m_model->index(i, m_mapper->mapValues()), Qt::DisplayRole).toDouble()); | |
|
700 | slice->setLabel(m_model->data(m_model->index(i, m_mapper->mapLabels()), Qt::DisplayRole).toString()); | |
|
701 | } else { | |
|
702 | slice->setValue(m_model->data(m_model->index(m_mapper->mapValues(), i), Qt::DisplayRole).toDouble()); | |
|
703 | slice->setLabel(m_model->data(m_model->index(m_mapper->mapLabels(), i), Qt::DisplayRole).toString()); | |
|
704 | } | |
|
705 | slice->setLabelVisible(); | |
|
706 | q->insert(i - m_mapper->first(), slice); | |
|
707 | } | |
|
708 | if (m_mapper->count() != -1 && m_slices.size() > m_mapper->count()) | |
|
709 | for (int i = m_slices.size() - 1; i >= m_mapper->count(); i--) | |
|
710 | q->remove(q->slices().at(i)); | |
|
711 | } | |
|
712 | } | |
|
713 | } | |
|
714 | ||
|
715 | void QPieSeriesPrivate::removeData(int start, int end) | |
|
716 | { | |
|
717 | Q_Q(QPieSeries); | |
|
718 | if (m_mapper) { | |
|
719 | int removedCount = end - start + 1; | |
|
720 | if (m_mapper->count() != -1 && start >= m_mapper->first() + m_mapper->count()) { | |
|
721 | return; | |
|
722 | } else { | |
|
723 | int toRemove = qMin(m_slices.size(), removedCount); // first find how many items can actually be removed | |
|
724 | int first = qMax(start, m_mapper->first()); // get the index of the first item that will be removed. | |
|
725 | int last = qMin(first + toRemove - 1, m_slices.size() + m_mapper->first() - 1); // get the index of the last item that will be removed. | |
|
726 | for (int i = last; i >= first; i--) | |
|
727 | q->remove(q->slices().at(i - m_mapper->first())); | |
|
728 | ||
|
729 | if (m_mapper->count() != -1) { | |
|
730 | int itemsAvailable; // check how many are available to be added | |
|
731 | if (m_mapper->orientation() == Qt::Vertical) | |
|
732 | itemsAvailable = m_model->rowCount() - m_mapper->first() - m_slices.size(); | |
|
733 | else | |
|
734 | itemsAvailable = m_model->columnCount() - m_mapper->first() - m_slices.size(); | |
|
735 | int toBeAdded = qMin(itemsAvailable, m_mapper->count() - m_slices.size()); // add not more items than there is space left to be filled. | |
|
736 | int currentSize = m_slices.size(); | |
|
737 | if (toBeAdded > 0) | |
|
738 | for (int i = m_slices.size(); i < currentSize + toBeAdded; i++) { | |
|
739 | QPieSlice *slice = new QPieSlice; | |
|
740 | if (m_mapper->orientation() == Qt::Vertical) { | |
|
741 | slice->setValue(m_model->data(m_model->index(i + m_mapper->first(), m_mapper->mapValues()), Qt::DisplayRole).toDouble()); | |
|
742 | slice->setLabel(m_model->data(m_model->index(i + m_mapper->first(), m_mapper->mapLabels()), Qt::DisplayRole).toString()); | |
|
743 | } else { | |
|
744 | slice->setValue(m_model->data(m_model->index(m_mapper->mapValues(), i + m_mapper->first()), Qt::DisplayRole).toDouble()); | |
|
745 | slice->setLabel(m_model->data(m_model->index(m_mapper->mapLabels(), i + m_mapper->first()), Qt::DisplayRole).toString()); | |
|
746 | } | |
|
747 | slice->setLabelVisible(); | |
|
748 | q->insert(i, slice); | |
|
749 | } | |
|
750 | } | |
|
751 | } | |
|
752 | } | |
|
753 | } | |
|
754 | ||
|
755 | void QPieSeriesPrivate::initializePieFromModel() | |
|
756 | { | |
|
757 | Q_Q(QPieSeries); | |
|
758 | ||
|
759 | // clear current content | |
|
760 | q->clear(); | |
|
761 | ||
|
762 | if (m_model == 0 || m_mapper == 0) | |
|
763 | return; | |
|
764 | ||
|
765 | // check if mappings are set | |
|
766 | if (m_mapper->mapValues() == -1 || m_mapper->mapLabels() == -1) | |
|
767 | return; | |
|
768 | ||
|
769 | // create the initial slices set | |
|
770 | if (m_mapper->orientation() == Qt::Vertical) { | |
|
771 | if (m_mapper->mapValues() >= m_model->columnCount() || m_mapper->mapLabels() >= m_model->columnCount()) | |
|
772 | return; // mapped columns are not existing | |
|
773 | ||
|
774 | int sliceCount = 0; | |
|
775 | if(m_mapper->count() == -1) | |
|
776 | sliceCount = m_model->rowCount() - m_mapper->first(); | |
|
777 | else | |
|
778 | sliceCount = qMin(m_mapper->count(), m_model->rowCount() - m_mapper->first()); | |
|
779 | for (int i = m_mapper->first(); i < m_mapper->first() + sliceCount; i++) | |
|
780 | q->append(m_model->data(m_model->index(i, m_mapper->mapLabels()), Qt::DisplayRole).toString(), m_model->data(m_model->index(i, m_mapper->mapValues()), Qt::DisplayRole).toDouble()); | |
|
781 | } else { | |
|
782 | if (m_mapper->mapValues() >= m_model->rowCount() || m_mapper->mapLabels() >= m_model->rowCount()) | |
|
783 | return; // mapped columns are not existing | |
|
784 | ||
|
785 | int sliceCount = 0; | |
|
786 | if(m_mapper->count() == -1) | |
|
787 | sliceCount = m_model->columnCount() - m_mapper->first(); | |
|
788 | else | |
|
789 | sliceCount = qMin(m_mapper->count(), m_model->columnCount() - m_mapper->first()); | |
|
790 | for (int i = m_mapper->first(); i < m_mapper->first() + sliceCount; i++) | |
|
791 | q->append(m_model->data(m_model->index(m_mapper->mapLabels(), i), Qt::DisplayRole).toString(), m_model->data(m_model->index(m_mapper->mapValues(), i), Qt::DisplayRole).toDouble()); | |
|
792 | } | |
|
793 | q->setLabelsVisible(true); | |
|
794 | } | |
|
795 | ||
|
796 | 614 | bool QPieSeriesPrivate::setRealValue(qreal &value, qreal newValue, qreal max, qreal min) |
|
797 | 615 | { |
|
798 | 616 | // Remove rounding errors |
@@ -847,6 +665,21 QList<LegendMarker*> QPieSeriesPrivate::createLegendMarker(QLegend* legend) | |||
|
847 | 665 | return markers; |
|
848 | 666 | } |
|
849 | 667 | |
|
668 | void QPieSeriesPrivate::setModel(QAbstractItemModel* model) | |
|
669 | { | |
|
670 | Q_Q(QPieSeries); | |
|
671 | QPieModelMapperPrivate *mapperPrivate = m_mapper->d_func(); | |
|
672 | mapperPrivate->setModel(model); | |
|
673 | if(mapperPrivate->m_series != q) | |
|
674 | { | |
|
675 | disconnect(mapperPrivate->m_series, 0, mapperPrivate, 0); | |
|
676 | mapperPrivate->m_series = q; | |
|
677 | connect(this, SIGNAL(added(QList<QPieSlice*>)), mapperPrivate, SLOT(slicesAdded())); | |
|
678 | connect(this, SIGNAL(removed(QList<QPieSlice*>)), mapperPrivate, SLOT(slicesRemoved())); | |
|
679 | connect(this, SIGNAL(modified()), mapperPrivate, SLOT(sliceChanged())); | |
|
680 | } | |
|
681 | } | |
|
682 | ||
|
850 | 683 | #include "moc_qpieseries.cpp" |
|
851 | 684 | #include "moc_qpieseries_p.cpp" |
|
852 | 685 |
@@ -54,20 +54,18 public Q_SLOTS: | |||
|
54 | 54 | void sliceChanged(); |
|
55 | 55 | void sliceClicked(); |
|
56 | 56 | void sliceHovered(bool state); |
|
57 | void initializePieFromModel(); | |
|
58 | void modelUpdated(QModelIndex topLeft, QModelIndex bottomRight); | |
|
59 | void modelRowsAdded(QModelIndex parent, int start, int end); | |
|
60 | void modelRowsRemoved(QModelIndex parent, int start, int end); | |
|
61 | void modelColumnsAdded(QModelIndex parent, int start, int end); | |
|
62 | void modelColumnsRemoved(QModelIndex parent, int start, int end); | |
|
57 | // void initializePieFromModel(); | |
|
58 | // void modelUpdated(QModelIndex topLeft, QModelIndex bottomRight); | |
|
59 | // void modelRowsAdded(QModelIndex parent, int start, int end); | |
|
60 | // void modelRowsRemoved(QModelIndex parent, int start, int end); | |
|
61 | // void modelColumnsAdded(QModelIndex parent, int start, int end); | |
|
62 | // void modelColumnsRemoved(QModelIndex parent, int start, int end); | |
|
63 | 63 | bool setRealValue(qreal &value, qreal newValue, qreal max, qreal min = 0.0); |
|
64 | 64 | |
|
65 | 65 | private: |
|
66 | void doClear(); | |
|
67 | void doRemove(QPieSlice* slice); | |
|
68 | void doInsert(int index, QPieSlice* slice); | |
|
69 | void insertData(int start, int end); | |
|
70 | void removeData(int start, int end); | |
|
66 | void setModel(QAbstractItemModel *model); | |
|
67 | // void insertData(int start, int end); | |
|
68 | // void removeData(int start, int end); | |
|
71 | 69 | |
|
72 | 70 | public: |
|
73 | 71 | QList<QPieSlice*> m_slices; |
General Comments 0
You need to be logged in to leave comments.
Login now