diff options
Diffstat (limited to 'qt-ui/diveplanner.cpp')
-rw-r--r-- | qt-ui/diveplanner.cpp | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 3e107b10c..a7bd0af4c 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -363,6 +363,10 @@ bool DivePlannerGraphics::isPointOutOfBoundaries(const QPointF& point) void DivePlannerGraphics::mousePressEvent(QMouseEvent* event) { + if (event->modifiers()){ + QGraphicsView::mousePressEvent(event); + } + QPointF mappedPos = mapToScene(event->pos()); Q_FOREACH(QGraphicsItem *item, scene()->items(mappedPos, Qt::IntersectsItemBoundingRect, Qt::AscendingOrder, transform())){ if (DiveHandler *h = qgraphicsitem_cast<DiveHandler*>(item)) { @@ -371,7 +375,6 @@ void DivePlannerGraphics::mousePressEvent(QMouseEvent* event) originalHandlerPos = activeDraggedHandler->pos(); } } - QGraphicsView::mousePressEvent(event); } void DivePlannerGraphics::mouseReleaseEvent(QMouseEvent* event) @@ -406,10 +409,21 @@ DiveHandler::DiveHandler(): QGraphicsEllipseItem(), from(0), to(0) { setRect(-5,-5,10,10); setFlag(QGraphicsItem::ItemIgnoresTransformations); + setFlag(QGraphicsItem::ItemIsSelectable); setBrush(Qt::white); setZValue(2); } +void DiveHandler::mousePressEvent(QGraphicsSceneMouseEvent* event) +{ + if (event->modifiers().testFlag(Qt::ControlModifier)){ + setSelected(true); + } + // mousePressEvent 'grabs' the mouse and keyboard, annoying. + ungrabMouse(); + ungrabKeyboard(); +} + void Ruler::setMaximum(double maximum) { max = maximum; |