diff options
author | Berthold Stoeger <bstoeger@mail.tuwien.ac.at> | 2021-01-25 15:51:37 +0100 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2021-04-02 13:53:23 -0700 |
commit | 91136b2c510f4a63d451678deadc2f5c131136aa (patch) | |
tree | 5699ecca004ced6e4491907f585149317b739a73 | |
parent | b9673df60bcc7f3135abc6dd866c3b412be46f92 (diff) | |
download | subsurface-91136b2c510f4a63d451678deadc2f5c131136aa.tar.gz |
profile: remove special casing of handle moving
When moving the handle with the mouse, the old code tried
to be smart about changing the active handle when crossing
handles.
To me this always felt weird and it was inconsistent with
mouse-move. Theregore, simply do nothing special at all. The
user should hopefully get an intiutive grasp of what's going
on when moving one handler across another.
Signed-off-by: Berthold Stoeger <bstoeger@mail.tuwien.ac.at>
-rw-r--r-- | profile-widget/profilewidget2.cpp | 38 | ||||
-rw-r--r-- | profile-widget/profilewidget2.h | 2 |
2 files changed, 6 insertions, 34 deletions
diff --git a/profile-widget/profilewidget2.cpp b/profile-widget/profilewidget2.cpp index 0058eecdf..38bbfdd00 100644 --- a/profile-widget/profilewidget2.cpp +++ b/profile-widget/profilewidget2.cpp @@ -1712,7 +1712,7 @@ DiveHandler *ProfileWidget2::createHandle() { DiveHandler *item = new DiveHandler(&displayed_dive); scene()->addItem(item); - connect(item, &DiveHandler::moved, this, &ProfileWidget2::recreatePlannedDive); + connect(item, &DiveHandler::moved, this, &ProfileWidget2::divePlannerHandlerMoved); connect(item, &DiveHandler::clicked, this, &ProfileWidget2::divePlannerHandlerClicked); connect(item, &DiveHandler::released, this, &ProfileWidget2::divePlannerHandlerReleased); return item; @@ -1798,49 +1798,21 @@ void ProfileWidget2::repositionDiveHandlers() } } -int ProfileWidget2::fixHandlerIndex(DiveHandler *activeHandler) -{ - int index = handleIndex(activeHandler); - if (index > 0 && index < (int)handles.size() - 1) { - DiveHandler *before = handles[index - 1].get(); - if (before->pos().x() > activeHandler->pos().x()) { - std::swap(handles[index], handles[index - 1]); - return index - 1; - } - DiveHandler *after = handles[index + 1].get(); - if (after->pos().x() < activeHandler->pos().x()) { - std::swap(handles[index], handles[index + 1]); - return index + 1; - } - } - return index; -} - -void ProfileWidget2::recreatePlannedDive() +void ProfileWidget2::divePlannerHandlerMoved() { DiveHandler *activeHandler = qobject_cast<DiveHandler *>(sender()); - int index = fixHandlerIndex(activeHandler); - int mintime = 0; - int maxtime = plannerModel->at(plannerModel->size() - 1).time * 3 / 2; - if (index > 0) - mintime = plannerModel->at(index - 1).time; - if (index < plannerModel->size() - 1) - maxtime = plannerModel->at(index + 1).time; + int index = handleIndex(activeHandler); + // Grow the time axis if necessary. int minutes = lrint(timeAxis->valueAt(activeHandler->pos()) / 60); - if (minutes * 60 <= mintime || minutes * 60 >= maxtime) - return; if (minutes * 60 > timeAxis->maximum() * 0.9) timeAxis->setMaximum(timeAxis->maximum() * 1.02); divedatapoint data = plannerModel->at(index); - depth_t oldDepth = data.depth; - int oldtime = data.time; data.depth.mm = lrint(profileYAxis->valueAt(activeHandler->pos()) / M_OR_FT(1, 1)) * M_OR_FT(1, 1); data.time = lrint(timeAxis->valueAt(activeHandler->pos())); - if (data.depth.mm != oldDepth.mm || data.time != oldtime) - plannerModel->editStop(index, data); + plannerModel->editStop(index, data); } void ProfileWidget2::keyDownAction() diff --git a/profile-widget/profilewidget2.h b/profile-widget/profilewidget2.h index 2437574a1..db9949d7b 100644 --- a/profile-widget/profilewidget2.h +++ b/profile-widget/profilewidget2.h @@ -124,7 +124,7 @@ slots: // Necessary to call from QAction's signals. void removePicture(const QString &fileUrl); /* this is called for every move on the handlers. maybe we can speed up this a bit? */ - void recreatePlannedDive(); + void divePlannerHandlerMoved(); /* key press handlers */ void keyEscAction(); |