aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAbyss777 <abyss@fox5.ru>2016-10-25 12:11:44 +0500
committerAbyss777 <abyss@fox5.ru>2016-10-25 12:11:44 +0500
commit419a008c13e6d388e56ac1961a2fc6959df87ab4 (patch)
tree1c7fa63736592a26c4c2d4674dc6c0fef3106f89
parent5c3ddc72a207bf67a7c4e4229aa1783dbb20d070 (diff)
downloadtrackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.tar.gz
trackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.tar.bz2
trackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.zip
Improved checks of last and new position
-rw-r--r--src/org/traccar/CoordinatesHandler.java7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/org/traccar/CoordinatesHandler.java b/src/org/traccar/CoordinatesHandler.java
index 53b33ebbc..703361ecf 100644
--- a/src/org/traccar/CoordinatesHandler.java
+++ b/src/org/traccar/CoordinatesHandler.java
@@ -39,11 +39,12 @@ public class CoordinatesHandler extends BaseDataHandler {
@Override
protected Position handlePosition(Position position) {
Position last = getLastPosition(position.getDeviceId());
- if (last != null && last.getLatitude() != 0 && last.getLongitude() != 0) {
+ if (last != null && last.getValid() && last.getLatitude() != 0 && last.getLongitude() != 0) {
double distance = DistanceCalculator.distance(
position.getLatitude(), position.getLongitude(), last.getLatitude(), last.getLongitude());
- if (coordinatesMinError != 0 && distance < coordinatesMinError
- || coordinatesMaxError != 0 && distance > coordinatesMaxError && !position.getValid()) {
+ boolean satisfiesMin = coordinatesMinError == 0 || distance > coordinatesMinError;
+ boolean satisfiesMax = coordinatesMaxError == 0 || distance < coordinatesMaxError || position.getValid();
+ if (!(satisfiesMin && satisfiesMax)) {
position.setLatitude(last.getLatitude());
position.setLongitude(last.getLongitude());
}