diff options
author | Abyss777 <abyss@fox5.ru> | 2016-10-25 12:11:44 +0500 |
---|---|---|
committer | Abyss777 <abyss@fox5.ru> | 2016-10-25 12:11:44 +0500 |
commit | 419a008c13e6d388e56ac1961a2fc6959df87ab4 (patch) | |
tree | 1c7fa63736592a26c4c2d4674dc6c0fef3106f89 /src | |
parent | 5c3ddc72a207bf67a7c4e4229aa1783dbb20d070 (diff) | |
download | trackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.tar.gz trackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.tar.bz2 trackermap-server-419a008c13e6d388e56ac1961a2fc6959df87ab4.zip |
Improved checks of last and new position
Diffstat (limited to 'src')
-rw-r--r-- | src/org/traccar/CoordinatesHandler.java | 7 |
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()); } |