summaryrefslogtreecommitdiffstats
path: root/qt-ui/diveplanner.cpp
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-06-20 13:56:28 -0300
committerGravatar Tomaz Canabrava <tcanabrava@kde.org>2013-06-20 13:56:28 -0300
commit46483a096f98b3dc7186bb6971d6e5009cfb2b13 (patch)
tree98255ac12b64887c39a37486b7631c6ad6ff876f /qt-ui/diveplanner.cpp
parent88e7aa36be99d9ae985a374a23d84d8e0f969b5a (diff)
downloadsubsurface-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.cpp25
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;
+}