From cec30c27d936a45d87e707363f824653949a5c02 Mon Sep 17 00:00:00 2001 From: Tomaz Canabrava Date: Thu, 14 Nov 2013 23:29:36 -0200 Subject: Enable a context menu to remove dive handlers. This commit enables a context menu to remove dive handlers, because it was hard to find that ctrl+click selected it, then a delete button press removed it. it's better now. :) Signed-off-by: Tomaz Canabrava Signed-off-by: Dirk Hohndel --- qt-ui/diveplanner.cpp | 29 ++++++++++++++++++++++++----- qt-ui/diveplanner.h | 9 +++++++-- 2 files changed, 31 insertions(+), 7 deletions(-) (limited to 'qt-ui') diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 34c729944..0b5b3301e 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -673,11 +673,13 @@ void DivePlannerGraphics::mousePressEvent(QMouseEvent* event) } QPointF mappedPos = mapToScene(event->pos()); - Q_FOREACH(QGraphicsItem *item, scene()->items(mappedPos, Qt::IntersectsItemBoundingRect, Qt::AscendingOrder, transform())) { - if (DiveHandler *h = qgraphicsitem_cast(item)) { - activeDraggedHandler = h; - activeDraggedHandler->setBrush(Qt::red); - originalHandlerPos = activeDraggedHandler->pos(); + if (event->button() == Qt::LeftButton){ + Q_FOREACH(QGraphicsItem *item, scene()->items(mappedPos, Qt::IntersectsItemBoundingRect, Qt::AscendingOrder, transform())) { + if (DiveHandler *h = qgraphicsitem_cast(item)) { + activeDraggedHandler = h; + activeDraggedHandler->setBrush(Qt::red); + originalHandlerPos = activeDraggedHandler->pos(); + } } } QGraphicsView::mousePressEvent(event); @@ -703,8 +705,25 @@ DiveHandler::DiveHandler(): QGraphicsEllipseItem() setZValue(2); } +void DiveHandler::contextMenuEvent(QGraphicsSceneContextMenuEvent* event) +{ + QMenu m; + m.addAction(QObject::tr("Remove this Point"), this, SLOT(selfRemove())); + m.exec(event->screenPos()); +} + +void DiveHandler::selfRemove() +{ + setSelected(true); + DivePlannerGraphics *view = qobject_cast(scene()->views().first()); + view->keyDeleteAction(); +} + void DiveHandler::mousePressEvent(QGraphicsSceneMouseEvent* event) { + if (event->button() != Qt::LeftButton) + return; + if (event->modifiers().testFlag(Qt::ControlModifier)) { setSelected(true); } diff --git a/qt-ui/diveplanner.h b/qt-ui/diveplanner.h index 232b8f0fe..bd9b254d1 100644 --- a/qt-ui/diveplanner.h +++ b/qt-ui/diveplanner.h @@ -95,11 +95,15 @@ private: QGraphicsSimpleTextItem *text; }; -class DiveHandler : public QGraphicsEllipseItem{ +class DiveHandler : public QObject, public QGraphicsEllipseItem{ +Q_OBJECT public: DiveHandler(); protected: void mousePressEvent(QGraphicsSceneMouseEvent* event); + void contextMenuEvent(QGraphicsSceneContextMenuEvent* event); +public slots: + void selfRemove(); }; class Ruler : public QGraphicsLineItem{ @@ -118,7 +122,6 @@ public: qreal posAtValue(qreal value); void setColor(const QColor& color); void setTextColor(const QColor& color); - private: Qt::Orientation orientation; QList ticks; @@ -210,6 +213,8 @@ private: int minMinutes; // this holds the minimum duration of the dive. int dpMaxTime; // this is the time of the dive calculated by the deco. + + friend class DiveHandler; }; #include "ui_diveplanner.h" -- cgit v1.2.3-70-g09d2