From 6be968854d7a134cf31b8af7b8ffb219da5cee55 Mon Sep 17 00:00:00 2001 From: liurunyu <lry9898@163.com> Date: 星期五, 05 七月 2024 16:36:40 +0800 Subject: [PATCH] p206V1.0.0协议与硬件联调,并修改完善代码。 --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java | 47 ++++++++++++++++++++++++++--------------------- 1 files changed, 26 insertions(+), 21 deletions(-) diff --git a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java index 6f32f1c..e81594f 100644 --- a/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java +++ b/pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java @@ -53,29 +53,29 @@ /** * 鍒嗘瀽鐘舵�佷笌鎶ヨ - * @param bs - * @param index + * @param bs 涓婃姤鏁版嵁鐨勫瓧鑺傛暟缁� + * @param index 褰撳墠瑙f瀽鏁扮粍涓嬫爣浣嶇疆 * @return */ public static void parseAlarmAndState(byte[] bs, int index, AlarmVo vo){ - byte b = bs[index + 1] ; + byte b = bs[index] ; vo.statePump = (byte)(b & 0x1) ; - vo.alarmWaterRemain = (byte)(b >> 1 & 1) ; - vo.alarm0WaterRemain = (byte)(b >> 2 & 1) ; - vo.alarmExceedYear = (byte)(b >> 3 & 1) ; - vo.alarmWaterMeterFault = (byte)(b >> 4 & 1) ; - vo.alarmSteal = (byte)(b >> 5 & 1) ; - vo.alarmWaterMeterBreak = (byte)(b >> 6 & 1) ; - vo.alarmEleMeterFault = (byte)(b >> 7 & 1) ; + vo.alarmWaterRemain = (byte)((b >> 1) & 1) ; + vo.alarm0WaterRemain = (byte)((b >> 2) & 1) ; + vo.alarmExceedYear = (byte)((b >> 3) & 1) ; + vo.alarmWaterMeterFault = (byte)((b >> 4) & 1) ; + vo.alarmSteal = (byte)((b >> 5) & 1) ; + vo.alarmWaterMeterBreak = (byte)((b >> 6) & 1) ; + vo.alarmEleMeterFault = (byte)((b >> 7) & 1) ; - b = bs[index] ; + b = bs[index + 1] ; vo.alarm0MoneyRemain = (byte)(b & 0x1) ; - vo.alarmInnerDoor = (byte)(b >> 1 & 1) ; - vo.alarmOuterDoor = (byte)(b >> 2 & 1) ; - vo.alarmEleMiss = (byte)(b >> 3 & 1) ; - vo.alarmEleExceed = (byte)(b >> 4 & 1) ; - vo.alarmEleLowVolt = (byte)(b >> 5 & 1) ; - vo.stateIcEnable = (byte)(b >> 6 & 1) ; + vo.alarmInnerDoor = (byte)((b >> 1) & 1) ; + vo.alarmOuterDoor = (byte)((b >> 2) & 1) ; + vo.alarmEleMiss = (byte)((b >> 3) & 1) ; + vo.alarmEleExceed = (byte)((b >> 4) & 1) ; + vo.alarmEleLowVolt = (byte)((b >> 5) & 1) ; + vo.stateIcEnable = (byte)((b >> 6) & 1) ; } public static String parseTp(byte[] bs, short index){ @@ -179,9 +179,9 @@ cdData.elePrice = elePrice/100.0D; index += 2 ; - GlParse.parseAlarmAndState(bs, index, cdData) ; + GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭 - index += 2 ; + index += 4 ; int aVolt = ByteUtil.BCD2Int_LE(bs, index, index + 1) ; cdData.aVolt = aVolt/10.0D; @@ -279,7 +279,7 @@ cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ; index += 2 ; - GlParse.parseAlarmAndState(bs, index, cdData) ; + GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭 } /** * 鍒嗘瀽鍔熻兘93銆丄3鏁版嵁 @@ -312,6 +312,11 @@ index += 8 ; cdData.startDt = GlParse.parseRtuDt(bs, index) ; + if(cdData.opResult == (byte)0x81){ + //澶辫触浜嗭紝涓嬮潰灏辨病鏈夋暟鎹簡 + return ; + } + index += 6 ; cdData.endDt = GlParse.parseRtuDt(bs, index) ; @@ -340,6 +345,6 @@ cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ; index += 2 ; - GlParse.parseAlarmAndState(bs, index, cdData) ; + GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭 } } -- Gitblit v1.8.0