diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2019-03-21 22:35:57 -0700 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2019-03-21 22:35:57 -0700 |
commit | a7c067243085ad62eefe5e6643b48ddd99793ad0 (patch) | |
tree | 5ca6e3c19d0fd96d4fb3a6b78b272f2d9850af3a /src/org | |
parent | c249e72c20c2046eef91fd602279e11e218159a3 (diff) | |
download | trackermap-server-a7c067243085ad62eefe5e6643b48ddd99793ad0.tar.gz trackermap-server-a7c067243085ad62eefe5e6643b48ddd99793ad0.tar.bz2 trackermap-server-a7c067243085ad62eefe5e6643b48ddd99793ad0.zip |
Additional ITS attributes
Diffstat (limited to 'src/org')
-rw-r--r-- | src/org/traccar/protocol/ItsProtocolDecoder.java | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/org/traccar/protocol/ItsProtocolDecoder.java b/src/org/traccar/protocol/ItsProtocolDecoder.java index a200ff8b7..a12b75961 100644 --- a/src/org/traccar/protocol/ItsProtocolDecoder.java +++ b/src/org/traccar/protocol/ItsProtocolDecoder.java @@ -63,6 +63,22 @@ public class ItsProtocolDecoder extends BaseProtocolDecoder { .number("(d+.?d*),") // speed .number("(d+.?d*),") // course .number("(d+),") // satellites + .groupBegin() + .number("(d+.?d*),") // altitude + .number("d+.?d*,") // pdop + .number("d+.?d*,") // hdop + .expression("[^,]*,") + .number("([01]),") // ignition + .number("([01]),") // charging + .number("(d+.?d*),") // power + .number("(d+.?d*),") // battery + .number("[01],") // emergency + .expression("[CO]?,") // tamper + .number("(?:x+,){5}") // main cell + .number("(?:-?x+,){12}") // other cells + .number("([01]{4}),") // inputs + .number("([01]{2}),") // outputs + .groupEnd("?") .or() .number("(-?d+.d+),") // altitude .number("(d+.d+),") // speed @@ -109,6 +125,16 @@ public class ItsProtocolDecoder extends BaseProtocolDecoder { position.set(Position.KEY_SATELLITES, parser.nextInt()); } + if (parser.hasNext(7)) { + position.setAltitude(parser.nextDouble()); + position.set(Position.KEY_IGNITION, parser.nextInt() > 0); + position.set(Position.KEY_CHARGE, parser.nextInt() > 0); + position.set(Position.KEY_POWER, parser.nextDouble()); + position.set(Position.KEY_BATTERY, parser.nextDouble()); + position.set(Position.KEY_INPUT, parser.nextBinInt()); + position.set(Position.KEY_OUTPUT, parser.nextBinInt()); + } + if (parser.hasNext(2)) { position.setAltitude(parser.nextDouble()); position.setSpeed(UnitsConverter.knotsFromKph(parser.nextDouble())); |