Improve smart recalculation
This commit is contained in:
parent
dc57d3929a
commit
85524b2ce7
2 changed files with 22 additions and 12 deletions
|
@ -213,18 +213,30 @@ public class BinaryRoutePlanner {
|
||||||
boolean runRecalculation = ctx.previouslyCalculatedRoute != null && ctx.previouslyCalculatedRoute.size() > 0;
|
boolean runRecalculation = ctx.previouslyCalculatedRoute != null && ctx.previouslyCalculatedRoute.size() > 0;
|
||||||
if (runRecalculation) {
|
if (runRecalculation) {
|
||||||
RouteSegment previous = null;
|
RouteSegment previous = null;
|
||||||
for (RouteSegmentResult rr : ctx.previouslyCalculatedRoute) {
|
List<RouteSegmentResult> rlist = new ArrayList<RouteSegmentResult>();
|
||||||
RouteSegment segment = new RouteSegment(rr.getObject(), rr.getEndPointIndex());
|
// always recalculate first 2.5 km
|
||||||
if (previous != null) {
|
int distanceThreshold = 2500;
|
||||||
previous.parentRoute = segment;
|
float threshold = 0;
|
||||||
previous.parentSegmentEnd = rr.getStartPointIndex();
|
for(RouteSegmentResult rr : ctx.previouslyCalculatedRoute) {
|
||||||
long t = (rr.getObject().getId() << ROUTE_POINTS) + segment.segmentStart;
|
threshold += rr.getDistance();
|
||||||
visitedOppositeSegments.put(t, segment);
|
if(threshold > distanceThreshold) {
|
||||||
|
rlist.add(rr);
|
||||||
}
|
}
|
||||||
previous = segment;
|
|
||||||
|
|
||||||
}
|
}
|
||||||
end = previous;
|
if (rlist.size() > 0) {
|
||||||
|
for (RouteSegmentResult rr : rlist) {
|
||||||
|
RouteSegment segment = new RouteSegment(rr.getObject(), rr.getEndPointIndex());
|
||||||
|
if (previous != null) {
|
||||||
|
previous.parentRoute = segment;
|
||||||
|
previous.parentSegmentEnd = rr.getStartPointIndex();
|
||||||
|
long t = (rr.getObject().getId() << ROUTE_POINTS) + segment.segmentStart;
|
||||||
|
visitedOppositeSegments.put(t, segment);
|
||||||
|
}
|
||||||
|
previous = segment;
|
||||||
|
|
||||||
|
}
|
||||||
|
end = previous;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// for start : f(start) = g(start) + h(start) = 0 + h(start) = h(start)
|
// for start : f(start) = g(start) + h(start) = 0 + h(start) = h(start)
|
||||||
|
|
|
@ -74,8 +74,6 @@ import android.view.Window;
|
||||||
import android.view.animation.AccelerateInterpolator;
|
import android.view.animation.AccelerateInterpolator;
|
||||||
import android.view.animation.Animation;
|
import android.view.animation.Animation;
|
||||||
import android.view.animation.Transformation;
|
import android.view.animation.Transformation;
|
||||||
import android.widget.FrameLayout.LayoutParams;
|
|
||||||
import android.widget.LinearLayout;
|
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
import android.widget.Toast;
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue