summaryrefslogtreecommitdiffstats
path: root/qt-ui
diff options
context:
space:
mode:
Diffstat (limited to 'qt-ui')
-rw-r--r--qt-ui/profile/ruleritem.cpp21
-rw-r--r--qt-ui/profile/ruleritem.h3
2 files changed, 6 insertions, 18 deletions
diff --git a/qt-ui/profile/ruleritem.cpp b/qt-ui/profile/ruleritem.cpp
index 295d81213..0bf97f947 100644
--- a/qt-ui/profile/ruleritem.cpp
+++ b/qt-ui/profile/ruleritem.cpp
@@ -9,6 +9,7 @@
#include <QPainter>
#include <QGraphicsScene>
#include <QGraphicsView>
+#include <qgraphicssceneevent.h>
#include <QDebug>
#include <stdint.h>
@@ -58,23 +59,11 @@ void RulerNodeItem2::recalculate()
}
}
-QVariant RulerNodeItem2::itemChange(GraphicsItemChange change, const QVariant &value)
+void RulerNodeItem2::mouseMoveEvent(QGraphicsSceneMouseEvent *event)
{
- // only run this if we actually have a ruler and are not adding or planning a dive
- ProfileWidget2 *profWidget = NULL;
- if (scene() && scene()->views().count())
- profWidget = qobject_cast<ProfileWidget2 *>(scene()->views().first());
- if (ruler &&
- profWidget &&
- !profWidget->isAddOrPlanner() &&
- change == ItemPositionHasChanged) {
- recalculate();
- ruler->recalculate();
- } else {
- if (profWidget && profWidget->isAddOrPlanner())
- qDebug() << "don't recalc ruler on Add/Plan";
- }
- return QGraphicsEllipseItem::itemChange(change, value);
+ setPos(event->scenePos());
+ recalculate();
+ ruler->recalculate();
}
RulerItem2::RulerItem2() : source(new RulerNodeItem2()),
diff --git a/qt-ui/profile/ruleritem.h b/qt-ui/profile/ruleritem.h
index 3eda33225..5d144f286 100644
--- a/qt-ui/profile/ruleritem.h
+++ b/qt-ui/profile/ruleritem.h
@@ -21,8 +21,7 @@ public:
void recalculate();
protected:
- QVariant itemChange(GraphicsItemChange change, const QVariant &value);
-
+ virtual void mouseMoveEvent(QGraphicsSceneMouseEvent *event);
private:
struct plot_info pInfo;
struct plot_data *entry;