summaryrefslogtreecommitdiffstats
path: root/profile-widget
diff options
context:
space:
mode:
Diffstat (limited to 'profile-widget')
-rw-r--r--profile-widget/profilewidget2.cpp52
-rw-r--r--profile-widget/profilewidget2.h8
2 files changed, 44 insertions, 16 deletions
diff --git a/profile-widget/profilewidget2.cpp b/profile-widget/profilewidget2.cpp
index 4381e6963..16d08f119 100644
--- a/profile-widget/profilewidget2.cpp
+++ b/profile-widget/profilewidget2.cpp
@@ -778,7 +778,10 @@ void ProfileWidget2::plotDive(struct dive *d, bool force)
DivePlannerPointsModel *model = DivePlannerPointsModel::instance();
model->deleteTemporaryPlan();
}
- plotPictures();
+ if (printMode)
+ clearPictures();
+ else
+ plotPictures();
#endif
// OK, how long did this take us? Anything above the second is way too long,
@@ -1103,7 +1106,7 @@ void ProfileWidget2::setProfileState()
disconnectTemporaryConnections();
#ifndef SUBSURFACE_MOBILE
- connect(DivePictureModel::instance(), SIGNAL(dataChanged(QModelIndex, QModelIndex)), this, SLOT(plotPictures()));
+ connect(DivePictureModel::instance(), &DivePictureModel::dataChanged, this, &ProfileWidget2::updatePictures);
connect(DivePictureModel::instance(), SIGNAL(rowsInserted(const QModelIndex &, int, int)), this, SLOT(plotPictures()));
connect(DivePictureModel::instance(), SIGNAL(rowsRemoved(const QModelIndex &, int, int)), this, SLOT(plotPictures()));
#endif
@@ -1974,26 +1977,47 @@ void ProfileWidget2::keyEscAction()
plannerModel->cancelPlan();
}
-void ProfileWidget2::plotPictures()
+void ProfileWidget2::clearPictures()
{
- Q_FOREACH (DivePictureItem *item, pictures) {
- item->hide();
- item->deleteLater();
- }
pictures.clear();
+}
- if (printMode)
- return;
+void ProfileWidget2::updatePictures(const QModelIndex &from, const QModelIndex &to)
+{
+ DivePictureModel *m = DivePictureModel::instance();
+ for (int picNr = from.row(); picNr <= to.row(); ++picNr) {
+ int picItemNr = picNr - m->rowDDStart;
+ if (picItemNr < 0 || (size_t)picItemNr >= pictures.size())
+ return;
+ if (!pictures[picItemNr])
+ return;
- double x, y, lastX = -1.0, lastY = -1.0;
+ pictures[picItemNr]->setPixmap(m->index(picNr, 0).data(Qt::UserRole).value<QPixmap>());
+ }
+}
+
+void ProfileWidget2::plotPictures()
+{
DivePictureModel *m = DivePictureModel::instance();
+ pictures.resize(m->rowDDEnd - m->rowDDStart);
+
+ double x, y, lastX = -1.0, lastY = -1.0;
for (int i = m->rowDDStart; i < m->rowDDEnd; i++) {
+ int picItemNr = i - m->rowDDStart;
int offsetSeconds = m->index(i, 1).data(Qt::UserRole).value<int>();
// it's a correct picture, but doesn't have a timestamp: only show on the widget near the
- // information area.
- if (!offsetSeconds)
+ // information area. A null pointer in the pictures array indicates that this picture is not
+ // shown.
+ if (!offsetSeconds) {
+ pictures[picItemNr].reset();
continue;
- DivePictureItem *item = new DivePictureItem();
+ }
+ DivePictureItem *item = pictures[picItemNr].get();
+ if (!item) {
+ item = new DivePictureItem;
+ pictures[picItemNr].reset(item);
+ scene()->addItem(item);
+ }
item->setPixmap(m->index(i, 0).data(Qt::UserRole).value<QPixmap>());
item->setFileUrl(m->index(i, 1).data().toString());
// let's put the picture at the correct time, but at a fixed "depth" on the profile
@@ -2008,8 +2032,6 @@ void ProfileWidget2::plotPictures()
lastX = x;
lastY = y;
item->setPos(x, y);
- scene()->addItem(item);
- pictures.push_back(item);
}
}
#endif
diff --git a/profile-widget/profilewidget2.h b/profile-widget/profilewidget2.h
index 575680f68..7766c4eef 100644
--- a/profile-widget/profilewidget2.h
+++ b/profile-widget/profilewidget2.h
@@ -3,6 +3,8 @@
#define PROFILEWIDGET2_H
#include <QGraphicsView>
+#include <vector>
+#include <memory>
// /* The idea of this widget is to display and edit the profile.
// * It has:
@@ -121,6 +123,7 @@ slots: // Necessary to call from QAction's signals.
void deleteCurrentDC();
void pointInserted(const QModelIndex &parent, int start, int end);
void pointsRemoved(const QModelIndex &, int start, int end);
+ void updatePictures(const QModelIndex &from, const QModelIndex &to);
/* this is called for every move on the handlers. maybe we can speed up this a bit? */
void recreatePlannedDive();
@@ -164,6 +167,7 @@ private: /*methods*/
void addActionShortcut(const Qt::Key shortcut, void (ProfileWidget2::*slot)());
void createPPGas(PartialPressureGasItem *item, int verticalColumn, color_index_t color, color_index_t colorAlert,
double *thresholdSettingsMin, double *thresholdSettingsMax);
+ void clearPictures();
private:
DivePlotDataModel *dataModel;
int zoomLevel;
@@ -217,7 +221,9 @@ private:
bool printMode;
QList<QGraphicsSimpleTextItem *> gases;
- QList<DivePictureItem *> pictures;
+
+ // Use std::vector<> and std::unique_ptr<>, because QVector<QScopedPointer<...>> is unsupported.
+ std::vector<std::unique_ptr<DivePictureItem>> pictures;
//specifics for ADD and PLAN
#ifndef SUBSURFACE_MOBILE