diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2021-04-26 20:44:10 -0700 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2021-04-26 20:44:10 -0700 |
commit | 309e6a6d4e153b67aa598d67b45f3128716576b8 (patch) | |
tree | 688b2a3ed475fc1b114c3ec35c8dcf300befbf8a | |
parent | 802a0e395d48ac9dbab54a4c01227aec5801c6f3 (diff) | |
download | traccar-server-309e6a6d4e153b67aa598d67b45f3128716576b8.tar.gz traccar-server-309e6a6d4e153b67aa598d67b45f3128716576b8.tar.bz2 traccar-server-309e6a6d4e153b67aa598d67b45f3128716576b8.zip |
Decode alarm codes
-rw-r--r-- | src/main/java/org/traccar/protocol/StartekProtocolDecoder.java | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/src/main/java/org/traccar/protocol/StartekProtocolDecoder.java b/src/main/java/org/traccar/protocol/StartekProtocolDecoder.java index b80c8e174..9b3780d0f 100644 --- a/src/main/java/org/traccar/protocol/StartekProtocolDecoder.java +++ b/src/main/java/org/traccar/protocol/StartekProtocolDecoder.java @@ -69,6 +69,22 @@ public class StartekProtocolDecoder extends BaseProtocolDecoder { .any() .compile(); + private String decodeAlarm(int value) { + switch (value) { + case 5: + case 6: + return Position.ALARM_DOOR; + case 39: + return Position.ALARM_ACCELERATION; + case 40: + return Position.ALARM_BRAKING; + case 41: + return Position.ALARM_CORNERING; + default: + return null; + } + } + @Override protected Object decode( Channel channel, SocketAddress remoteAddress, Object msg) throws Exception { @@ -86,7 +102,9 @@ public class StartekProtocolDecoder extends BaseProtocolDecoder { Position position = new Position(getProtocolName()); position.setDeviceId(deviceSession.getDeviceId()); - position.set(Position.KEY_EVENT, parser.nextInt()); + int event = parser.nextInt(); + position.set(Position.KEY_ALARM, decodeAlarm(event)); + position.set(Position.KEY_EVENT, event); position.setTime(parser.nextDateTime()); position.setValid(parser.next().equals("A")); |