diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2014-11-15 16:30:26 +1300 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2014-11-15 16:30:26 +1300 |
commit | 419920eb18e775690736fd9eec048b3a186744e3 (patch) | |
tree | 74b2a6da3b9866d32100c2d5d920735c7bc35f8a /src/org/traccar/ReverseGeocoderHandler.java | |
parent | 74f88cf2cc40680869233bcdb97cece139985f96 (diff) | |
parent | cee5be49edbcef85e9eb7072a9b6723e2474c9cf (diff) | |
download | trackermap-server-419920eb18e775690736fd9eec048b3a186744e3.tar.gz trackermap-server-419920eb18e775690736fd9eec048b3a186744e3.tar.bz2 trackermap-server-419920eb18e775690736fd9eec048b3a186744e3.zip |
Merge pull request #973 from jon-stumpf/enhancement-new-geocode-option
Added geocode.processInvalidPositions option
Diffstat (limited to 'src/org/traccar/ReverseGeocoderHandler.java')
-rw-r--r-- | src/org/traccar/ReverseGeocoderHandler.java | 18 |
1 files changed, 12 insertions, 6 deletions
diff --git a/src/org/traccar/ReverseGeocoderHandler.java b/src/org/traccar/ReverseGeocoderHandler.java index 8bdd7ebfc..7a3372dff 100644 --- a/src/org/traccar/ReverseGeocoderHandler.java +++ b/src/org/traccar/ReverseGeocoderHandler.java @@ -18,7 +18,6 @@ package org.traccar; import java.util.List; import org.jboss.netty.channel.Channel; import org.jboss.netty.channel.ChannelHandlerContext; -import org.jboss.netty.channel.MessageEvent; import org.jboss.netty.handler.codec.oneone.OneToOneDecoder; import org.traccar.geocode.ReverseGeocoder; import org.traccar.model.Position; @@ -26,9 +25,11 @@ import org.traccar.model.Position; public class ReverseGeocoderHandler extends OneToOneDecoder { private final ReverseGeocoder geocoder; + private final boolean processInvalidPositions; - public ReverseGeocoderHandler(ReverseGeocoder geocoder) { + public ReverseGeocoderHandler(ReverseGeocoder geocoder, boolean processInvalidPositions ) { this.geocoder = geocoder; + this.processInvalidPositions = processInvalidPositions; } @Override @@ -39,13 +40,18 @@ public class ReverseGeocoderHandler extends OneToOneDecoder { if (geocoder != null) { if (msg instanceof Position) { Position position = (Position) msg; - position.setAddress(geocoder.getAddress( - position.getLatitude(), position.getLongitude())); + + if (processInvalidPositions || position.getValid()) { + position.setAddress(geocoder.getAddress( + position.getLatitude(), position.getLongitude())); + } } else if (msg instanceof List) { List<Position> positions = (List<Position>) msg; for (Position position : positions) { - position.setAddress(geocoder.getAddress( - position.getLatitude(), position.getLongitude())); + if (processInvalidPositions || position.getValid()) { + position.setAddress(geocoder.getAddress( + position.getLatitude(), position.getLongitude())); + } } } } |