OsmAnd/OsmAnd-java/src/main/java/net/osmand/router/RouteSegmentResult.java

232 lines
5.7 KiB
Java
Raw Normal View History

package net.osmand.router;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
2016-12-22 01:34:22 +01:00
import net.osmand.binary.BinaryMapRouteReaderAdapter.RouteTypeRule;
import net.osmand.binary.RouteDataObject;
import net.osmand.data.LatLon;
2016-12-22 01:34:22 +01:00
import net.osmand.util.Algorithms;
import net.osmand.util.MapUtils;
public class RouteSegmentResult {
private final RouteDataObject object;
private int startPointIndex;
private int endPointIndex;
private List<RouteSegmentResult>[] attachedRoutes;
private RouteSegmentResult[][] preAttachedRoutes;
private float segmentTime;
2014-01-28 21:03:25 +01:00
private float routingTime;
private float speed;
private float distance;
private String description = "";
// this make not possible to make turns in between segment result for now
private TurnType turnType;
public RouteSegmentResult(RouteDataObject object, int startPointIndex, int endPointIndex) {
this.object = object;
this.startPointIndex = startPointIndex;
this.endPointIndex = endPointIndex;
updateCapacity();
}
2016-12-22 01:34:22 +01:00
public float[] getHeightValues() {
2017-02-08 09:54:38 +01:00
float[] pf = object.calculateHeightArray();
if(pf == null || pf.length == 0) {
2016-12-22 01:34:22 +01:00
return new float[0];
}
boolean reverse = startPointIndex > endPointIndex;
int st = Math.min(startPointIndex, endPointIndex);
int end = Math.max(startPointIndex, endPointIndex);
float[] res = new float[(end - st + 1) * 2];
for (int k = 0; k < res.length / 2; k++) {
2017-02-08 22:02:47 +01:00
int ind = reverse ? (2 * (end - k)) : (2 * (k + st));
2016-12-22 01:34:22 +01:00
if (k == 0) {
res[2 * k] = 0;
} else {
2017-02-08 22:02:47 +01:00
if(ind < pf.length) {
res[2 * k] = pf[ind];
2017-02-08 22:02:47 +01:00
}
}
if(ind < pf.length) {
res[2 * k + 1] = pf[ind + 1];
2016-12-22 01:34:22 +01:00
}
}
return res;
}
@SuppressWarnings("unchecked")
private void updateCapacity() {
int capacity = Math.abs(endPointIndex - startPointIndex) + 1;
2013-10-29 21:13:57 +01:00
List<RouteSegmentResult>[] old = this.attachedRoutes;
this.attachedRoutes = new List[capacity];
if(old != null){
System.arraycopy(old, 0, this.attachedRoutes, 0, Math.min(old.length, this.attachedRoutes.length));
}
}
public void attachRoute(int roadIndex, RouteSegmentResult r){
2018-05-25 23:12:50 +02:00
if(r.getObject().isRoadDeleted()) {
return;
}
int st = Math.abs(roadIndex - startPointIndex);
if(attachedRoutes[st] == null) {
attachedRoutes[st] = new ArrayList<RouteSegmentResult>();
}
attachedRoutes[st].add(r);
}
public void copyPreattachedRoutes(RouteSegmentResult toCopy, int shift) {
if(toCopy.preAttachedRoutes != null) {
int l = toCopy.preAttachedRoutes.length - shift;
preAttachedRoutes = new RouteSegmentResult[l][];
System.arraycopy(toCopy.preAttachedRoutes, shift, preAttachedRoutes, 0, l);
}
}
public RouteSegmentResult[] getPreAttachedRoutes(int routeInd) {
int st = Math.abs(routeInd - startPointIndex);
if(preAttachedRoutes != null && st < preAttachedRoutes.length) {
return preAttachedRoutes[st];
}
return null;
}
public List<RouteSegmentResult> getAttachedRoutes(int routeInd) {
int st = Math.abs(routeInd - startPointIndex);
List<RouteSegmentResult> list = attachedRoutes[st];
if(list == null) {
return Collections.emptyList();
}
return list;
}
public TurnType getTurnType() {
return turnType;
}
public void setTurnType(TurnType turnType) {
this.turnType = turnType;
}
public RouteDataObject getObject() {
return object;
}
public float getSegmentTime() {
return segmentTime;
}
public float getBearingBegin() {
return (float) (object.directionRoute(startPointIndex, startPointIndex < endPointIndex) / Math.PI * 180);
}
public float getBearing(int point, boolean plus) {
return (float) (object.directionRoute(point, plus) / Math.PI * 180);
}
2013-11-26 16:23:05 +01:00
public float getDistance(int point, boolean plus) {
return (float) (plus? object.distance(point, endPointIndex): object.distance(startPointIndex, point));
}
public float getBearingEnd() {
return (float) (MapUtils.alignAngleDifference(object.directionRoute(endPointIndex, startPointIndex > endPointIndex) - Math.PI) / Math.PI * 180);
}
public void setSegmentTime(float segmentTime) {
this.segmentTime = segmentTime;
}
2014-01-28 21:03:25 +01:00
public void setRoutingTime(float routingTime) {
this.routingTime = routingTime;
}
public float getRoutingTime() {
return routingTime;
}
public LatLon getStartPoint() {
return convertPoint(object, startPointIndex);
}
public int getStartPointIndex() {
return startPointIndex;
}
public int getEndPointIndex() {
return endPointIndex;
}
public LatLon getPoint(int i) {
return convertPoint(object, i);
}
public LatLon getEndPoint() {
return convertPoint(object, endPointIndex);
}
2014-10-02 14:14:34 +02:00
public boolean isForwardDirection() {
return endPointIndex - startPointIndex > 0;
}
private LatLon convertPoint(RouteDataObject o, int ind){
return new LatLon(MapUtils.get31LatitudeY(o.getPoint31YTile(ind)), MapUtils.get31LongitudeX(o.getPoint31XTile(ind)));
}
public void setSegmentSpeed(float speed) {
this.speed = speed;
}
public void setEndPointIndex(int endPointIndex) {
this.endPointIndex = endPointIndex;
updateCapacity();
}
public void setStartPointIndex(int startPointIndex) {
this.startPointIndex = startPointIndex;
updateCapacity();
}
public float getSegmentSpeed() {
return speed;
}
public float getDistance() {
return distance;
}
public void setDistance(float distance) {
this.distance = distance;
}
public String getDescription() {
return description;
}
public void setDescription(String description) {
this.description = description;
}
@Override
public String toString() {
2016-08-29 00:19:19 +02:00
return object.toString() + ": " + startPointIndex + "-" + endPointIndex;
}
2018-10-26 15:33:56 +02:00
public String getSurface() {
return object.getValue("surface");
}
public String getSmoothness() {
return object.getValue("smoothness");
}
public String getHighway() {
return object.getHighway();
}
}