From 92bbed3304afeb8e7ef6593f48eae982d799b5f1 Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Tue, 11 Feb 2014 12:05:33 -0800 Subject: Take the on-canvas position into account for DiveCartesianAxis::valueAt() We did this right for posAtValue(), but not for the inverse. Fixes #438 Signed-off-by: Dirk Hohndel --- qt-ui/profile/divecartesianaxis.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) (limited to 'qt-ui/profile/divecartesianaxis.cpp') diff --git a/qt-ui/profile/divecartesianaxis.cpp b/qt-ui/profile/divecartesianaxis.cpp index c780b7a63..3fdafa375 100644 --- a/qt-ui/profile/divecartesianaxis.cpp +++ b/qt-ui/profile/divecartesianaxis.cpp @@ -187,12 +187,15 @@ void DiveCartesianAxis::setTickInterval(double i) interval = i; } -qreal DiveCartesianAxis::valueAt(const QPointF& p) +qreal DiveCartesianAxis::valueAt(const QPointF& p) const { QLineF m = line(); + QPointF relativePosition = p; + relativePosition -= pos(); // normalize p based on the axis' offset on screen + double retValue = (orientation == LeftToRight || orientation == RightToLeft) ? - max * (p.x() - m.x1()) / (m.x2() - m.x1()) : - max * (p.y() - m.y1()) / (m.y2() - m.y1()); + max * (relativePosition.x() - m.x1()) / (m.x2() - m.x1()) : + max * (relativePosition.y() - m.y1()) / (m.y2() - m.y1()); return retValue; } -- cgit v1.2.3-70-g09d2