aboutsummaryrefslogtreecommitdiff
path: root/src/org
diff options
context:
space:
mode:
authorEvgeny S Maksimov <me@vragam.net>2019-01-21 22:55:20 +0300
committerEvgeny S Maksimov <me@vragam.net>2019-01-21 22:55:20 +0300
commiteae48f944a326bac20e49dac4fe577e7cc2a4102 (patch)
tree91d21b18c13fb58240c2bea1307534c88de1fe4c /src/org
parentf61893727534e888cf2143557bf6f143bdd64e60 (diff)
downloadtraccar-server-eae48f944a326bac20e49dac4fe577e7cc2a4102.tar.gz
traccar-server-eae48f944a326bac20e49dac4fe577e7cc2a4102.tar.bz2
traccar-server-eae48f944a326bac20e49dac4fe577e7cc2a4102.zip
Fixed two-field parameters
Diffstat (limited to 'src/org')
-rw-r--r--src/org/traccar/protocol/NavisProtocolDecoder.java13
1 files changed, 6 insertions, 7 deletions
diff --git a/src/org/traccar/protocol/NavisProtocolDecoder.java b/src/org/traccar/protocol/NavisProtocolDecoder.java
index 4e5162b44..93e751012 100644
--- a/src/org/traccar/protocol/NavisProtocolDecoder.java
+++ b/src/org/traccar/protocol/NavisProtocolDecoder.java
@@ -329,6 +329,9 @@ public class NavisProtocolDecoder extends BaseProtocolDecoder {
position.setDeviceId(deviceSession.getDeviceId());
long index = 0;
+ int status = 0;
+ short input = 0;
+ short output = 0;
for (int i = 0; i < flexBitfieldDataSize; i++) {
if ((flexBitfield[(int) (i / 8)] & (0x80 >> i % 8)) == 0) {
@@ -336,10 +339,6 @@ public class NavisProtocolDecoder extends BaseProtocolDecoder {
continue;
}
- int status = 0;
- short input = 0;
- short output = 0;
-
switch (i) {
case 0:
index = buf.readUnsignedIntLE();
@@ -361,7 +360,7 @@ public class NavisProtocolDecoder extends BaseProtocolDecoder {
break;
case 5:
int status2 = buf.readUnsignedByte();
- position.set(Position.KEY_STATUS, (short) ((status & 0xFF) | (status2 << 1)));
+ position.set(Position.KEY_STATUS, (short) ((status & 0xFF) | (status2 << 8)));
break;
case 6:
position.set(Position.KEY_RSSI, buf.readUnsignedByte());
@@ -420,7 +419,7 @@ public class NavisProtocolDecoder extends BaseProtocolDecoder {
break;
case 29:
short input2 = buf.readUnsignedByte();
- position.set(Position.KEY_INPUT, (short) ((input & 0xFF) | (input2 << 1)));
+ position.set(Position.KEY_INPUT, (short) ((input & 0xFF) | (input2 << 8)));
for (int k = 0; k < 8; k++) {
position.set(Position.PREFIX_IN + (k + 9), BitUtil.check(input2, k));
}
@@ -434,7 +433,7 @@ public class NavisProtocolDecoder extends BaseProtocolDecoder {
break;
case 31:
short output2 = buf.readUnsignedByte();
- position.set(Position.KEY_OUTPUT, (short) ((output & 0xFF) | (output2 << 1)));
+ position.set(Position.KEY_OUTPUT, (short) ((output & 0xFF) | (output2 << 8)));
for (int k = 0; k < 8; k++) {
position.set(Position.PREFIX_OUT + (k + 9), BitUtil.check(output2, k));
}