diff options
author | Tomaz Canabrava <tcanabrava@kde.org> | 2013-07-04 10:06:52 -0300 |
---|---|---|
committer | Tomaz Canabrava <tcanabrava@kde.org> | 2013-07-04 10:06:52 -0300 |
commit | 603d2f5cb3c748bbb64711a99d1c115f6407d09e (patch) | |
tree | 0fd185b3fa9d0be4c70cf1196bf9a79da25286e1 /qt-ui/diveplanner.cpp | |
parent | 55f8979160080998e5353a5cbecf00e9995c5db2 (diff) | |
download | subsurface-603d2f5cb3c748bbb64711a99d1c115f6407d09e.tar.gz |
Make it possible to add a handler between others
Make it possible to add a handler between others,
someone asked why I didn't make like this from the
beginning, the answer is that I wanted to have something
stable before messing a bit more with the planner, but
since the planer is almost-stable, I added. :)
Signed-off-by: Tomaz Canabrava <tcanabrava@kde.org>
Diffstat (limited to 'qt-ui/diveplanner.cpp')
-rw-r--r-- | qt-ui/diveplanner.cpp | 26 |
1 files changed, 18 insertions, 8 deletions
diff --git a/qt-ui/diveplanner.cpp b/qt-ui/diveplanner.cpp index 8b82d9573..d4c6e9561 100644 --- a/qt-ui/diveplanner.cpp +++ b/qt-ui/diveplanner.cpp @@ -18,6 +18,10 @@ #define MAX_DEEPNESS 150 #define MIN_DEEPNESS 40 +bool handlerLessThenMinutes(DiveHandler *d1, DiveHandler *d2){ + return d1->sec < d2->sec; +} + DivePlannerGraphics::DivePlannerGraphics(QWidget* parent): QGraphicsView(parent), activeDraggedHandler(0), lastValidPos(0.0, 0.0) { @@ -163,21 +167,25 @@ void DivePlannerGraphics::mouseDoubleClickEvent(QMouseEvent* event) if (isPointOutOfBoundaries(mappedPos)) return; - if (handles.count() && handles.last()->x() > mappedPos.x()) - return; - - DiveHandler *item = new DiveHandler (); - item->setRect(-5,-5,10,10); - item->setFlag(QGraphicsItem::ItemIgnoresTransformations); int minutes = rint(timeLine->valueAt(mappedPos)); int meters = rint(depthLine->valueAt(mappedPos)); - item->sec = minutes * 60; - item->mm = meters * 1000; double xpos = timeLine->posAtValue(minutes); double ypos = depthLine->posAtValue(meters); + Q_FOREACH(DiveHandler* handler, handles){ + if (xpos == handler->pos().x()){ + qDebug() << "There's already an point at that place."; + //TODO: Move this later to a KMessageWidget. + return; + } + } + + DiveHandler *item = new DiveHandler (); + item->sec = minutes * 60; + item->mm = meters * 1000; item->setPos(QPointF(xpos, ypos)); scene()->addItem(item); handles << item; + qSort(handles.begin(), handles.end(), handlerLessThenMinutes); createDecoStops(); } @@ -403,6 +411,8 @@ void DivePlannerGraphics::mouseReleaseEvent(QMouseEvent* event) DiveHandler::DiveHandler(): QGraphicsEllipseItem(), from(0), to(0) { + setRect(-5,-5,10,10); + setFlag(QGraphicsItem::ItemIgnoresTransformations); setBrush(Qt::white); setZValue(2); } |