diff options
author | Tomaz Canabrava <tcanabrava@kde.org> | 2013-06-20 13:56:28 -0300 |
---|---|---|
committer | Tomaz Canabrava <tcanabrava@kde.org> | 2013-06-20 13:56:28 -0300 |
commit | 46483a096f98b3dc7186bb6971d6e5009cfb2b13 (patch) | |
tree | 98255ac12b64887c39a37486b7631c6ad6ff876f /qt-ui/diveplanner.cpp | |
parent | 88e7aa36be99d9ae985a374a23d84d8e0f969b5a (diff) | |
download | subsurface-46483a096f98b3dc7186bb6971d6e5009cfb2b13.tar.gz |
Better defaults for placement of dive stops.
This patch makes it impossible to create a dive stop
outside of the scene - this, messing the complete
planning system.
Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
Diffstat (limited to 'qt-ui/diveplanner.cpp')
-rw-r--r-- | qt-ui/diveplanner.cpp | 25 |
1 files changed, 18 insertions, 7 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 13f15a2e0..d4dd7d5bf 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -25,9 +25,13 @@ DivePlanner::DivePlanner(QWidget* parent): QGraphicsView(parent) void DivePlanner::mouseDoubleClickEvent(QMouseEvent* event) { + QPointF mappedPos = mapToScene(event->pos()); + if(isPointOutOfBoundaries(mappedPos)) + return; + QGraphicsEllipseItem *item = new QGraphicsEllipseItem(-5,-5,10,10); item->setFlag(QGraphicsItem::ItemIgnoresTransformations); - QPointF mappedPos = mapToScene(event->pos()); + item->setPos( mappedPos ); scene()->addItem(item); @@ -81,13 +85,20 @@ void DivePlanner::showEvent(QShowEvent* event) void DivePlanner::mouseMoveEvent(QMouseEvent* event) { QPointF mappedPos = mapToScene(event->pos()); - if (mappedPos.x() > sceneRect().width() - || mappedPos.x() < 0 - || mappedPos.y() < 0 - || mappedPos.y() > sceneRect().height()) - { + if (isPointOutOfBoundaries(mappedPos)) return; - } verticalLine->setLine(mappedPos.x(), 0, mappedPos.x(), 100); horizontalLine->setLine(0, mappedPos.y(), 100, mappedPos.y()); } + +bool DivePlanner::isPointOutOfBoundaries(QPointF point) +{ + if (point.x() > sceneRect().width() + || point.x() < 0 + || point.y() < 0 + || point.y() > sceneRect().height()) + { + return true; + } + return false; +} |