From 7ddadf9811f1918918797890b5de403b45aed59a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20T=C5=AFma?= Date: Sun, 7 Nov 2021 12:11:53 +0100 Subject: [PATCH] Use a faster segment lookup (in case there are many segments) + remove the "overflow safe" index computations - we shall really not exceed 2^30 track points in a single track... --- src/GUI/graphitem.cpp | 28 +++++++++++++++++++++------- 1 file changed, 21 insertions(+), 7 deletions(-) diff --git a/src/GUI/graphitem.cpp b/src/GUI/graphitem.cpp index 2baa2f39..cf819d9b 100644 --- a/src/GUI/graphitem.cpp +++ b/src/GUI/graphitem.cpp @@ -78,11 +78,25 @@ void GraphItem::setWidth(int width) const GraphSegment *GraphItem::segment(qreal x, GraphType type) const { - for (int i = 0; i < _graph.size(); i++) - if (x <= _graph.at(i).last().x(type)) - return &(_graph.at(i)); + int low = 0; + int high = _graph.size() - 1; + int mid = 0; - return 0; + while (low <= high) { + mid = (high + low) / 2; + const GraphPoint &p = _graph.at(mid).last(); + if (p.x(_type) > x) + high = mid - 1; + else if (p.x(_type) < x) + low = mid + 1; + else + return &(_graph.at(mid)); + } + + if (_graph.at(mid).last().x(type) < x) + return (mid == _graph.size() - 1) ? 0 : &(_graph.at(mid+1)); + else + return &(_graph.at(mid)); } qreal GraphItem::yAtX(qreal x) const @@ -99,7 +113,7 @@ qreal GraphItem::yAtX(qreal x) const return NAN; while (low <= high) { - mid = low + ((high - low) / 2); + mid = (high + low) / 2; const GraphPoint &p = seg->at(mid); if (p.x(_type) > x) high = mid - 1; @@ -137,7 +151,7 @@ qreal GraphItem::distanceAtTime(qreal time) const return NAN; while (low <= high) { - mid = low + ((high - low) / 2); + mid = (high + low) / 2; const GraphPoint &p = seg->at(mid); if (p.t() > time) high = mid - 1; @@ -175,7 +189,7 @@ qreal GraphItem::timeAtDistance(qreal distance) const return NAN; while (low <= high) { - mid = low + ((high - low) / 2); + mid = (high + low) / 2; const GraphPoint &p = seg->at(mid); if (p.s() > distance) high = mid - 1;