diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2018-05-16 22:50:24 +0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2018-05-17 07:22:04 -0700 |
commit | f54268e527764dac4893ad68703a7fa67c2d1ecb (patch) | |
tree | caf7c70f76036e3cf1984772f2157ca7fa3616b8 /profile-widget | |
parent | afe88435094fbb1aa179baab5e2e16249258851a (diff) | |
download | subsurface-f54268e527764dac4893ad68703a7fa67c2d1ecb.tar.gz |
Dive pictures: Fix crash on picture delete
The recent simplification of the close button code introduced a crash:
Deletion of pictures caused an invalid memory access, because the
CloseButtonItem was deleted with the parent DivePicture item.
For some (not fully understood!) reason, a reference to this button
was stored in the depths of Qt.
Empirically, it was found out that removing the first line of the pair
QGraphicsItem::mousePressEvent(event);
emit clicked();
fixed the crash.
It seemed therefore prudent to remove the whole questionable signal/slot
mechanism and directly call the removePicture() function of the parent.
Thus, the intermediate DiveButtonItem class became unnecessary and was
removed, leading to a shallower class hierarchy.
Unfortunately, CloseButtonItem must still be derived from QObject owing
to the Q_PROPERTY machinery, which is in turn needed for animation.
To make this compile on mobile, the conditional compilation of
removePicture() (#ifndef SUBSURFACE_MOBILE) was removed. After all,
if DivePixmapItem is used, there are pictures, so removePicture()
should be functional. Conditional compilation should concern the
whole class, not only this function.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
Diffstat (limited to 'profile-widget')
-rw-r--r-- | profile-widget/divepixmapitem.cpp | 26 | ||||
-rw-r--r-- | profile-widget/divepixmapitem.h | 16 |
2 files changed, 13 insertions, 29 deletions
diff --git a/profile-widget/divepixmapitem.cpp b/profile-widget/divepixmapitem.cpp index 08525fe34..0d1051dad 100644 --- a/profile-widget/divepixmapitem.cpp +++ b/profile-widget/divepixmapitem.cpp @@ -16,31 +16,26 @@ DivePixmapItem::DivePixmapItem(QGraphicsItem *parent) : QGraphicsPixmapItem(pare { } -DiveButtonItem::DiveButtonItem(QGraphicsItem *parent): DivePixmapItem(parent) -{ -} - -void DiveButtonItem::mousePressEvent(QGraphicsSceneMouseEvent *event) -{ - QGraphicsItem::mousePressEvent(event); - emit clicked(); -} - -CloseButtonItem::CloseButtonItem(QGraphicsItem *parent): DiveButtonItem(parent) +CloseButtonItem::CloseButtonItem(QGraphicsItem *parent): DivePixmapItem(parent) { static QPixmap p = QPixmap(":list-remove-icon"); setPixmap(p); setFlag(ItemIgnoresTransformations); } +void CloseButtonItem::mousePressEvent(QGraphicsSceneMouseEvent *event) +{ + qgraphicsitem_cast<DivePictureItem*>(parentItem())->removePicture(); +} + void CloseButtonItem::hide() { - DiveButtonItem::hide(); + DivePixmapItem::hide(); } void CloseButtonItem::show() { - DiveButtonItem::show(); + DivePixmapItem::show(); } DivePictureItem::DivePictureItem(QGraphicsItem *parent): DivePixmapItem(parent), @@ -96,7 +91,6 @@ void DivePictureItem::hoverEnterEvent(QGraphicsSceneHoverEvent *event) button->setOpacity(0); button->show(); Animations::show(button); - connect(button, SIGNAL(clicked()), this, SLOT(removePicture())); } void DivePictureItem::setFileUrl(const QString &s) @@ -119,9 +113,9 @@ void DivePictureItem::mousePressEvent(QGraphicsSceneMouseEvent *event) } } -#ifndef SUBSURFACE_MOBILE void DivePictureItem::removePicture() { +#ifndef SUBSURFACE_MOBILE DivePictureModel::instance()->removePicture(fileUrl, true); -} #endif +} diff --git a/profile-widget/divepixmapitem.h b/profile-widget/divepixmapitem.h index 16dbdf8fa..6abe410a6 100644 --- a/profile-widget/divepixmapitem.h +++ b/profile-widget/divepixmapitem.h @@ -15,20 +15,12 @@ public: DivePixmapItem(QGraphicsItem *parent = 0); }; -class DiveButtonItem : public DivePixmapItem { +class CloseButtonItem : public DivePixmapItem { Q_OBJECT public: - DiveButtonItem(QGraphicsItem *parent = 0); + CloseButtonItem(QGraphicsItem *parent = 0); protected: virtual void mousePressEvent(QGraphicsSceneMouseEvent *event); -signals: - void clicked(); -}; - -class CloseButtonItem : public DiveButtonItem { - Q_OBJECT -public: - CloseButtonItem(QGraphicsItem *parent = 0); public slots: void hide(); void show(); @@ -42,9 +34,7 @@ public: void setPixmap(const QPixmap& pix); public slots: void settingsChanged(); -#ifndef SUBSURFACE_MOBILE void removePicture(); -#endif void setFileUrl(const QString& s); protected: void hoverEnterEvent(QGraphicsSceneHoverEvent *event); @@ -54,7 +44,7 @@ private: QString fileUrl; QGraphicsRectItem *canvas; QGraphicsRectItem *shadow; - DiveButtonItem *button; + CloseButtonItem *button; }; #endif // DIVEPIXMAPITEM_H |