Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
dc6f4f7ecb
3 changed files with 78 additions and 79 deletions
|
@ -68,7 +68,7 @@ public class GPXUtilities {
|
||||||
|
|
||||||
@ColorInt
|
@ColorInt
|
||||||
public int getColor(@ColorInt int defColor) {
|
public int getColor(@ColorInt int defColor) {
|
||||||
if(extensions != null && extensions.containsKey("color")) {
|
if (extensions != null && extensions.containsKey("color")) {
|
||||||
try {
|
try {
|
||||||
return Color.parseColor(extensions.get("color").toUpperCase());
|
return Color.parseColor(extensions.get("color").toUpperCase());
|
||||||
} catch (IllegalArgumentException e) {
|
} catch (IllegalArgumentException e) {
|
||||||
|
@ -77,7 +77,7 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
return defColor;
|
return defColor;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setColor(int color) {
|
public void setColor(int color) {
|
||||||
getExtensionsToWrite().put("color", Algorithms.colorToString(color));
|
getExtensionsToWrite().put("color", Algorithms.colorToString(color));
|
||||||
}
|
}
|
||||||
|
@ -105,8 +105,8 @@ public class GPXUtilities {
|
||||||
public double speed = 0;
|
public double speed = 0;
|
||||||
public double hdop = Double.NaN;
|
public double hdop = Double.NaN;
|
||||||
public boolean deleted = false;
|
public boolean deleted = false;
|
||||||
public int colourARGB = 0; // point colour (used for altitude/speed colouring)
|
public int colourARGB = 0; // point colour (used for altitude/speed colouring)
|
||||||
public double distance = 0.0; // cumulative distance, if in a track
|
public double distance = 0.0; // cumulative distance, if in a track
|
||||||
|
|
||||||
public WptPt() {
|
public WptPt() {
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ public class GPXUtilities {
|
||||||
return lon;
|
return lon;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public PointDescription getPointDescription(Context ctx) {
|
public PointDescription getPointDescription(Context ctx) {
|
||||||
return new PointDescription(PointDescription.POINT_TYPE_WPT, name);
|
return new PointDescription(PointDescription.POINT_TYPE_WPT, name);
|
||||||
|
@ -211,11 +211,11 @@ public class GPXUtilities {
|
||||||
public List<GPXTrackAnalysis> splitByDistance(double meters) {
|
public List<GPXTrackAnalysis> splitByDistance(double meters) {
|
||||||
return split(getDistanceMetric(), getTimeSplit(), meters);
|
return split(getDistanceMetric(), getTimeSplit(), meters);
|
||||||
}
|
}
|
||||||
|
|
||||||
public List<GPXTrackAnalysis> splitByTime(int seconds) {
|
public List<GPXTrackAnalysis> splitByTime(int seconds) {
|
||||||
return split(getTimeSplit(), getDistanceMetric(), seconds);
|
return split(getTimeSplit(), getDistanceMetric(), seconds);
|
||||||
}
|
}
|
||||||
|
|
||||||
private List<GPXTrackAnalysis> split(SplitMetric metric, SplitMetric secondaryMetric, double metricLimit) {
|
private List<GPXTrackAnalysis> split(SplitMetric metric, SplitMetric secondaryMetric, double metricLimit) {
|
||||||
List<SplitSegment> splitSegments = new ArrayList<GPXUtilities.SplitSegment>();
|
List<SplitSegment> splitSegments = new ArrayList<GPXUtilities.SplitSegment>();
|
||||||
splitSegment(metric, secondaryMetric, metricLimit, splitSegments, this);
|
splitSegment(metric, secondaryMetric, metricLimit, splitSegments, this);
|
||||||
|
@ -242,7 +242,7 @@ public class GPXUtilities {
|
||||||
public List<WptPt> points = new ArrayList<WptPt>();
|
public List<WptPt> points = new ArrayList<WptPt>();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class GPXTrackAnalysis {
|
public static class GPXTrackAnalysis {
|
||||||
public float totalDistance = 0;
|
public float totalDistance = 0;
|
||||||
public int totalTracks = 0;
|
public int totalTracks = 0;
|
||||||
|
@ -257,13 +257,13 @@ public class GPXUtilities {
|
||||||
public double avgElevation = 0;
|
public double avgElevation = 0;
|
||||||
public double minElevation = 99999;
|
public double minElevation = 99999;
|
||||||
public double maxElevation = -100;
|
public double maxElevation = -100;
|
||||||
|
|
||||||
public float maxSpeed = 0;
|
public float maxSpeed = 0;
|
||||||
public float avgSpeed;
|
public float avgSpeed;
|
||||||
|
|
||||||
public int points;
|
public int points;
|
||||||
public int wptPoints = 0;
|
public int wptPoints = 0;
|
||||||
|
|
||||||
public double metricEnd;
|
public double metricEnd;
|
||||||
public double secondaryMetricEnd;
|
public double secondaryMetricEnd;
|
||||||
public WptPt locationStart;
|
public WptPt locationStart;
|
||||||
|
@ -272,24 +272,24 @@ public class GPXUtilities {
|
||||||
public boolean isTimeSpecified() {
|
public boolean isTimeSpecified() {
|
||||||
return startTime != Long.MAX_VALUE && startTime != 0;
|
return startTime != Long.MAX_VALUE && startTime != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isTimeMoving() {
|
public boolean isTimeMoving() {
|
||||||
return timeMoving != 0;
|
return timeMoving != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isElevationSpecified() {
|
public boolean isElevationSpecified() {
|
||||||
return maxElevation != -100;
|
return maxElevation != -100;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isSpeedSpecified() {
|
public boolean isSpeedSpecified() {
|
||||||
return avgSpeed > 0;
|
return avgSpeed > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public static GPXTrackAnalysis segment(long filetimestamp, TrkSegment segment) {
|
public static GPXTrackAnalysis segment(long filetimestamp, TrkSegment segment) {
|
||||||
return new GPXTrackAnalysis().prepareInformation(filetimestamp, new SplitSegment(segment));
|
return new GPXTrackAnalysis().prepareInformation(filetimestamp, new SplitSegment(segment));
|
||||||
}
|
}
|
||||||
|
|
||||||
public GPXTrackAnalysis prepareInformation(long filestamp, SplitSegment... splitSegments) {
|
public GPXTrackAnalysis prepareInformation(long filestamp, SplitSegment... splitSegments) {
|
||||||
float[] calculations = new float[1];
|
float[] calculations = new float[1];
|
||||||
|
|
||||||
|
@ -298,7 +298,7 @@ public class GPXUtilities {
|
||||||
int speedCount = 0;
|
int speedCount = 0;
|
||||||
double totalSpeedSum = 0;
|
double totalSpeedSum = 0;
|
||||||
points = 0;
|
points = 0;
|
||||||
|
|
||||||
double channelThresMin = 5; // Minimum oscillation amplitude considered as noise for Up/Down analysis
|
double channelThresMin = 5; // Minimum oscillation amplitude considered as noise for Up/Down analysis
|
||||||
double channelThres = channelThresMin; // Actual oscillation amplitude considered as noise, try depedency on current hdop
|
double channelThres = channelThresMin; // Actual oscillation amplitude considered as noise, try depedency on current hdop
|
||||||
double channelBase;
|
double channelBase;
|
||||||
|
@ -319,10 +319,10 @@ public class GPXUtilities {
|
||||||
points += numberOfPoints;
|
points += numberOfPoints;
|
||||||
for (int j = 0; j < numberOfPoints; j++) {
|
for (int j = 0; j < numberOfPoints; j++) {
|
||||||
WptPt point = s.get(j);
|
WptPt point = s.get(j);
|
||||||
if(j == 0 && locationStart == null) {
|
if (j == 0 && locationStart == null) {
|
||||||
locationStart = point;
|
locationStart = point;
|
||||||
}
|
}
|
||||||
if(j == numberOfPoints - 1) {
|
if (j == numberOfPoints - 1) {
|
||||||
locationEnd = point;
|
locationEnd = point;
|
||||||
}
|
}
|
||||||
long time = point.time;
|
long time = point.time;
|
||||||
|
@ -360,12 +360,12 @@ public class GPXUtilities {
|
||||||
if (point.ele > channelTop) {
|
if (point.ele > channelTop) {
|
||||||
channelTop = point.ele;
|
channelTop = point.ele;
|
||||||
if (!Double.isNaN(point.hdop)) {
|
if (!Double.isNaN(point.hdop)) {
|
||||||
channelThres = Math.max(channelThres, 2.0*point.hdop); //Try empirical 2*hdop, may better serve very flat tracks, or high dop tracks
|
channelThres = Math.max(channelThres, 2.0 * point.hdop); //Try empirical 2*hdop, may better serve very flat tracks, or high dop tracks
|
||||||
}
|
}
|
||||||
} else if (point.ele < channelBottom) {
|
} else if (point.ele < channelBottom) {
|
||||||
channelBottom = point.ele;
|
channelBottom = point.ele;
|
||||||
if (!Double.isNaN(point.hdop)) {
|
if (!Double.isNaN(point.hdop)) {
|
||||||
channelThres = Math.max(channelThres, 2.0*point.hdop);
|
channelThres = Math.max(channelThres, 2.0 * point.hdop);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// Turnaround (breakout) detection
|
// Turnaround (breakout) detection
|
||||||
|
@ -387,7 +387,7 @@ public class GPXUtilities {
|
||||||
channelThres = channelThresMin;
|
channelThres = channelThresMin;
|
||||||
}
|
}
|
||||||
// End detection without breakout
|
// End detection without breakout
|
||||||
if (j == (numberOfPoints -1)) {
|
if (j == (numberOfPoints - 1)) {
|
||||||
if ((channelTop - channelBase) >= channelThres) {
|
if ((channelTop - channelBase) >= channelThres) {
|
||||||
diffElevationUp += channelTop - channelBase;
|
diffElevationUp += channelTop - channelBase;
|
||||||
}
|
}
|
||||||
|
@ -424,7 +424,7 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!isTimeSpecified()){
|
if (!isTimeSpecified()) {
|
||||||
startTime = filestamp;
|
startTime = filestamp;
|
||||||
endTime = filestamp;
|
endTime = filestamp;
|
||||||
}
|
}
|
||||||
|
@ -437,35 +437,34 @@ public class GPXUtilities {
|
||||||
// 3. Time moving, if any
|
// 3. Time moving, if any
|
||||||
// 4. Elevation, eleUp, eleDown, if recorded
|
// 4. Elevation, eleUp, eleDown, if recorded
|
||||||
if (elevationPoints > 0) {
|
if (elevationPoints > 0) {
|
||||||
avgElevation = totalElevation / elevationPoints;
|
avgElevation = totalElevation / elevationPoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// 5. Max speed and Average speed, if any. Average speed is NOT overall (effective) speed, but only calculated for "moving" periods.
|
// 5. Max speed and Average speed, if any. Average speed is NOT overall (effective) speed, but only calculated for "moving" periods.
|
||||||
if(speedCount > 0) {
|
if (speedCount > 0) {
|
||||||
if(timeMoving > 0){
|
if (timeMoving > 0) {
|
||||||
avgSpeed = (float)totalDistanceMoving / (float)timeMoving * 1000f;
|
avgSpeed = (float) totalDistanceMoving / (float) timeMoving * 1000f;
|
||||||
} else {
|
} else {
|
||||||
avgSpeed = (float)totalSpeedSum / (float)speedCount;
|
avgSpeed = (float) totalSpeedSum / (float) speedCount;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
avgSpeed = -1;
|
avgSpeed = -1;
|
||||||
}
|
}
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static class SplitSegment {
|
private static class SplitSegment {
|
||||||
TrkSegment segment;
|
TrkSegment segment;
|
||||||
double startCoeff = 0;
|
double startCoeff = 0;
|
||||||
int startPointInd;
|
int startPointInd;
|
||||||
double endCoeff = 0;
|
double endCoeff = 0;
|
||||||
int endPointInd;
|
int endPointInd;
|
||||||
double metricEnd;
|
double metricEnd;
|
||||||
double secondaryMetricEnd;
|
double secondaryMetricEnd;
|
||||||
|
|
||||||
public SplitSegment(TrkSegment s) {
|
public SplitSegment(TrkSegment s) {
|
||||||
startPointInd = 0;
|
startPointInd = 0;
|
||||||
startCoeff = 0;
|
startCoeff = 0;
|
||||||
|
@ -473,28 +472,28 @@ public class GPXUtilities {
|
||||||
endCoeff = 1;
|
endCoeff = 1;
|
||||||
this.segment = s;
|
this.segment = s;
|
||||||
}
|
}
|
||||||
|
|
||||||
public SplitSegment(TrkSegment s, int pointInd, double cf) {
|
public SplitSegment(TrkSegment s, int pointInd, double cf) {
|
||||||
this.segment = s;
|
this.segment = s;
|
||||||
this.startPointInd = pointInd;
|
this.startPointInd = pointInd;
|
||||||
this.startCoeff = cf;
|
this.startCoeff = cf;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public int getNumberOfPoints() {
|
public int getNumberOfPoints() {
|
||||||
return endPointInd - startPointInd + 2;
|
return endPointInd - startPointInd + 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
public WptPt get(int j) {
|
public WptPt get(int j) {
|
||||||
final int ind = j + startPointInd;
|
final int ind = j + startPointInd;
|
||||||
if(j == 0) {
|
if (j == 0) {
|
||||||
if(startCoeff == 0) {
|
if (startCoeff == 0) {
|
||||||
return segment.points.get(ind);
|
return segment.points.get(ind);
|
||||||
}
|
}
|
||||||
return approx(segment.points.get(ind), segment.points.get(ind + 1), startCoeff);
|
return approx(segment.points.get(ind), segment.points.get(ind + 1), startCoeff);
|
||||||
}
|
}
|
||||||
if(j == getNumberOfPoints() - 1) {
|
if (j == getNumberOfPoints() - 1) {
|
||||||
if(endCoeff == 1) {
|
if (endCoeff == 1) {
|
||||||
return segment.points.get(ind);
|
return segment.points.get(ind);
|
||||||
}
|
}
|
||||||
return approx(segment.points.get(ind - 1), segment.points.get(ind), endCoeff);
|
return approx(segment.points.get(ind - 1), segment.points.get(ind), endCoeff);
|
||||||
|
@ -502,7 +501,7 @@ public class GPXUtilities {
|
||||||
return segment.points.get(ind);
|
return segment.points.get(ind);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private WptPt approx(WptPt w1, WptPt w2, double cf) {
|
private WptPt approx(WptPt w1, WptPt w2, double cf) {
|
||||||
long time = value(w1.time, w2.time, 0, cf);
|
long time = value(w1.time, w2.time, 0, cf);
|
||||||
double speed = value(w1.speed, w2.speed, 0, cf);
|
double speed = value(w1.speed, w2.speed, 0, cf);
|
||||||
|
@ -512,9 +511,9 @@ public class GPXUtilities {
|
||||||
double lon = value(w1.lon, w2.lon, -360, cf);
|
double lon = value(w1.lon, w2.lon, -360, cf);
|
||||||
return new WptPt(lat, lon, time, ele, speed, hdop);
|
return new WptPt(lat, lon, time, ele, speed, hdop);
|
||||||
}
|
}
|
||||||
|
|
||||||
private double value(double vl, double vl2, double none, double cf) {
|
private double value(double vl, double vl2, double none, double cf) {
|
||||||
if(vl == none || Double.isNaN(vl)) {
|
if (vl == none || Double.isNaN(vl)) {
|
||||||
return vl2;
|
return vl2;
|
||||||
} else if (vl2 == none || Double.isNaN(vl2)) {
|
} else if (vl2 == none || Double.isNaN(vl2)) {
|
||||||
return vl;
|
return vl;
|
||||||
|
@ -523,26 +522,26 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
|
|
||||||
private long value(long vl, long vl2, long none, double cf) {
|
private long value(long vl, long vl2, long none, double cf) {
|
||||||
if(vl == none) {
|
if (vl == none) {
|
||||||
return vl2;
|
return vl2;
|
||||||
} else if(vl2 == none) {
|
} else if (vl2 == none) {
|
||||||
return vl;
|
return vl;
|
||||||
}
|
}
|
||||||
return vl + ((long) (cf * (vl2 - vl)));
|
return vl + ((long) (cf * (vl2 - vl)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public double setLastPoint(int pointInd, double endCf) {
|
public double setLastPoint(int pointInd, double endCf) {
|
||||||
endCoeff = endCf;
|
endCoeff = endCf;
|
||||||
endPointInd = pointInd;
|
endPointInd = pointInd;
|
||||||
return endCoeff;
|
return endCoeff;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SplitMetric getDistanceMetric() {
|
private static SplitMetric getDistanceMetric() {
|
||||||
return new SplitMetric() {
|
return new SplitMetric() {
|
||||||
|
|
||||||
private float[] calculations = new float[1];
|
private float[] calculations = new float[1];
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -552,26 +551,26 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private static SplitMetric getTimeSplit() {
|
private static SplitMetric getTimeSplit() {
|
||||||
return new SplitMetric() {
|
return new SplitMetric() {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public double metric(WptPt p1, WptPt p2) {
|
public double metric(WptPt p1, WptPt p2) {
|
||||||
if(p1.time != 0 && p2.time != 0) {
|
if (p1.time != 0 && p2.time != 0) {
|
||||||
return (int) Math.abs((p2.time - p1.time) / 1000l);
|
return (int) Math.abs((p2.time - p1.time) / 1000l);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
private abstract static class SplitMetric {
|
private abstract static class SplitMetric {
|
||||||
|
|
||||||
public abstract double metric(WptPt p1, WptPt p2);
|
public abstract double metric(WptPt p1, WptPt p2);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void splitSegment(SplitMetric metric, SplitMetric secondaryMetric,
|
private static void splitSegment(SplitMetric metric, SplitMetric secondaryMetric,
|
||||||
double metricLimit, List<SplitSegment> splitSegments,
|
double metricLimit, List<SplitSegment> splitSegments,
|
||||||
TrkSegment segment) {
|
TrkSegment segment) {
|
||||||
|
@ -579,7 +578,7 @@ public class GPXUtilities {
|
||||||
double secondaryMetricEnd = 0;
|
double secondaryMetricEnd = 0;
|
||||||
SplitSegment sp = new SplitSegment(segment, 0, 0);
|
SplitSegment sp = new SplitSegment(segment, 0, 0);
|
||||||
double total = 0;
|
double total = 0;
|
||||||
WptPt prev = null ;
|
WptPt prev = null;
|
||||||
for (int k = 0; k < segment.points.size(); k++) {
|
for (int k = 0; k < segment.points.size(); k++) {
|
||||||
WptPt point = segment.points.get(k);
|
WptPt point = segment.points.get(k);
|
||||||
if (k > 0) {
|
if (k > 0) {
|
||||||
|
@ -587,12 +586,12 @@ public class GPXUtilities {
|
||||||
secondaryMetricEnd += secondaryMetric.metric(prev, point);
|
secondaryMetricEnd += secondaryMetric.metric(prev, point);
|
||||||
while (total + currentSegment > currentMetricEnd) {
|
while (total + currentSegment > currentMetricEnd) {
|
||||||
double p = currentMetricEnd - total;
|
double p = currentMetricEnd - total;
|
||||||
double cf = (p / currentSegment);
|
double cf = (p / currentSegment);
|
||||||
sp.setLastPoint(k - 1, cf);
|
sp.setLastPoint(k - 1, cf);
|
||||||
sp.metricEnd = currentMetricEnd;
|
sp.metricEnd = currentMetricEnd;
|
||||||
sp.secondaryMetricEnd = secondaryMetricEnd;
|
sp.secondaryMetricEnd = secondaryMetricEnd;
|
||||||
splitSegments.add(sp);
|
splitSegments.add(sp);
|
||||||
|
|
||||||
sp = new SplitSegment(segment, k - 1, cf);
|
sp = new SplitSegment(segment, k - 1, cf);
|
||||||
currentMetricEnd += metricLimit;
|
currentMetricEnd += metricLimit;
|
||||||
prev = sp.get(0);
|
prev = sp.get(0);
|
||||||
|
@ -612,20 +611,20 @@ public class GPXUtilities {
|
||||||
|
|
||||||
private static List<GPXTrackAnalysis> convert(List<SplitSegment> splitSegments) {
|
private static List<GPXTrackAnalysis> convert(List<SplitSegment> splitSegments) {
|
||||||
List<GPXTrackAnalysis> ls = new ArrayList<GPXUtilities.GPXTrackAnalysis>();
|
List<GPXTrackAnalysis> ls = new ArrayList<GPXUtilities.GPXTrackAnalysis>();
|
||||||
for(SplitSegment s : splitSegments) {
|
for (SplitSegment s : splitSegments) {
|
||||||
GPXTrackAnalysis a = new GPXTrackAnalysis();
|
GPXTrackAnalysis a = new GPXTrackAnalysis();
|
||||||
a.prepareInformation(0, s);
|
a.prepareInformation(0, s);
|
||||||
ls.add(a);
|
ls.add(a);
|
||||||
}
|
}
|
||||||
return ls;
|
return ls;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static class GPXFile extends GPXExtensions {
|
public static class GPXFile extends GPXExtensions {
|
||||||
public String author;
|
public String author;
|
||||||
public List<Track> tracks = new ArrayList<Track>();
|
public List<Track> tracks = new ArrayList<Track>();
|
||||||
public List<WptPt> points = new ArrayList<WptPt>();
|
public List<WptPt> points = new ArrayList<WptPt>();
|
||||||
public List<Route> routes = new ArrayList<Route>();
|
public List<Route> routes = new ArrayList<Route>();
|
||||||
|
|
||||||
public String warning = null;
|
public String warning = null;
|
||||||
public String path = "";
|
public String path = "";
|
||||||
public boolean showCurrentTrack;
|
public boolean showCurrentTrack;
|
||||||
|
@ -634,41 +633,41 @@ public class GPXUtilities {
|
||||||
public boolean isCloudmadeRouteFile() {
|
public boolean isCloudmadeRouteFile() {
|
||||||
return "cloudmade".equalsIgnoreCase(author);
|
return "cloudmade".equalsIgnoreCase(author);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public GPXTrackAnalysis getAnalysis(long fileTimestamp) {
|
public GPXTrackAnalysis getAnalysis(long fileTimestamp) {
|
||||||
GPXTrackAnalysis g = new GPXTrackAnalysis();
|
GPXTrackAnalysis g = new GPXTrackAnalysis();
|
||||||
g.wptPoints = points.size();
|
g.wptPoints = points.size();
|
||||||
List<SplitSegment> splitSegments = new ArrayList<GPXUtilities.SplitSegment>();
|
List<SplitSegment> splitSegments = new ArrayList<GPXUtilities.SplitSegment>();
|
||||||
for(int i = 0; i< tracks.size() ; i++){
|
for (int i = 0; i < tracks.size(); i++) {
|
||||||
Track subtrack = tracks.get(i);
|
Track subtrack = tracks.get(i);
|
||||||
for(TrkSegment segment : subtrack.segments){
|
for (TrkSegment segment : subtrack.segments) {
|
||||||
g.totalTracks ++;
|
g.totalTracks++;
|
||||||
if(segment.points.size() > 1) {
|
if (segment.points.size() > 1) {
|
||||||
splitSegments.add(new SplitSegment(segment));
|
splitSegments.add(new SplitSegment(segment));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
g.prepareInformation(fileTimestamp, splitSegments.toArray(new SplitSegment[splitSegments.size()]));
|
g.prepareInformation(fileTimestamp, splitSegments.toArray(new SplitSegment[splitSegments.size()]));
|
||||||
return g ;
|
return g;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public boolean hasRtePt() {
|
public boolean hasRtePt() {
|
||||||
for(Route r : routes) {
|
for (Route r : routes) {
|
||||||
if(r.points.size() > 0) {
|
if (r.points.size() > 0) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasWptPt() {
|
public boolean hasWptPt() {
|
||||||
return points.size() > 0;
|
return points.size() > 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean hasTrkPt() {
|
public boolean hasTrkPt() {
|
||||||
for(Track t : tracks) {
|
for (Track t : tracks) {
|
||||||
for (TrkSegment ts : t.segments) {
|
for (TrkSegment ts : t.segments) {
|
||||||
if (ts.points.size() > 0) {
|
if (ts.points.size() > 0) {
|
||||||
return true;
|
return true;
|
||||||
|
@ -751,7 +750,7 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
return tpoints;
|
return tpoints;
|
||||||
}
|
}
|
||||||
|
|
||||||
public WptPt getLastPoint() {
|
public WptPt getLastPoint() {
|
||||||
if (tracks.size() > 0) {
|
if (tracks.size() > 0) {
|
||||||
Track tk = tracks.get(tracks.size() - 1);
|
Track tk = tracks.get(tracks.size() - 1);
|
||||||
|
@ -926,7 +925,7 @@ public class GPXUtilities {
|
||||||
}
|
}
|
||||||
writeNotNullText(serializer, "name", p.name);
|
writeNotNullText(serializer, "name", p.name);
|
||||||
writeNotNullText(serializer, "desc", p.desc);
|
writeNotNullText(serializer, "desc", p.desc);
|
||||||
if(p.link != null) {
|
if (p.link != null) {
|
||||||
serializer.startTag(null, "link");
|
serializer.startTag(null, "link");
|
||||||
serializer.attribute(null, "href", p.link);
|
serializer.attribute(null, "href", p.link);
|
||||||
serializer.endTag(null, "link");
|
serializer.endTag(null, "link");
|
||||||
|
@ -1097,7 +1096,7 @@ public class GPXUtilities {
|
||||||
} else if (tag.equals("category")) {
|
} else if (tag.equals("category")) {
|
||||||
((WptPt) parse).category = readText(parser, "category");
|
((WptPt) parse).category = readText(parser, "category");
|
||||||
} else if (tag.equals("type")) {
|
} else if (tag.equals("type")) {
|
||||||
if(((WptPt) parse).category == null) {
|
if (((WptPt) parse).category == null) {
|
||||||
((WptPt) parse).category = readText(parser, "type");
|
((WptPt) parse).category = readText(parser, "type");
|
||||||
}
|
}
|
||||||
} else if (parser.getName().equals("ele")) {
|
} else if (parser.getName().equals("ele")) {
|
||||||
|
|
|
@ -539,7 +539,7 @@ public class MapActivity extends OsmandActionBarActivity implements DownloadEven
|
||||||
gpxImportHelper.handleFileImport(data, new File(data.getPath()).getName());
|
gpxImportHelper.handleFileImport(data, new File(data.getPath()).getName());
|
||||||
setIntent(null);
|
setIntent(null);
|
||||||
} else if ("content".equals(scheme)) {
|
} else if ("content".equals(scheme)) {
|
||||||
gpxImportHelper.handleContenImport(data);
|
gpxImportHelper.handleContentImport(data);
|
||||||
setIntent(null);
|
setIntent(null);
|
||||||
} else if ("google.navigation".equals(scheme) || "osmand.navigation".equals(scheme)) {
|
} else if ("google.navigation".equals(scheme) || "osmand.navigation".equals(scheme)) {
|
||||||
parseNavigationIntent(data);
|
parseNavigationIntent(data);
|
||||||
|
|
|
@ -52,7 +52,7 @@ public class GpxImportHelper {
|
||||||
this.mapView = mapView;
|
this.mapView = mapView;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void handleContenImport(final Uri contentUri) {
|
public void handleContentImport(final Uri contentUri) {
|
||||||
final String name = getNameFromContentUri(contentUri);
|
final String name = getNameFromContentUri(contentUri);
|
||||||
|
|
||||||
handleFileImport(contentUri, name);
|
handleFileImport(contentUri, name);
|
||||||
|
|
Loading…
Reference in a new issue