From 4513ef24bf9b188c2a77d6ce94f1a6b7e9ebf0e6 Mon Sep 17 00:00:00 2001 From: zuoxiao <470321431@qq.com> Date: 星期日, 27 四月 2025 20:40:19 +0800 Subject: [PATCH] fix(irrigatePlan): 修正灌溉计划开始时间逻辑 --- pipIrr-platform/pipIrr-common/src/main/java/com/dy/common/mw/protocol/p206V202404/parse/global/GlParse.java | 65 +++++++++++++++++++++----------- 1 files changed, 42 insertions(+), 23 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 dc2abe8..a2df974 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 @@ -1,5 +1,6 @@ package com.dy.common.mw.protocol.p206V202404.parse.global; +import com.dy.common.mw.protocol.p206V202404.CommonV202404; import com.dy.common.mw.protocol.p206V202404.ProtocolConstantV206V202404; import com.dy.common.mw.protocol.p206V202404.upVos.*; import com.dy.common.util.ByteUtil; @@ -53,29 +54,41 @@ /** * 鍒嗘瀽鐘舵�佷笌鎶ヨ - * @param bs - * @param index + * @param bs 涓婃姤鏁版嵁鐨勫瓧鑺傛暟缁� + * @param index 褰撳墠瑙f瀽鏁扮粍涓嬫爣浣嶇疆 * @return */ public static void parseAlarmAndState(byte[] bs, int index, AlarmVo vo){ 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) ; + + //涓庢祴鎺т竴浣撻榾鍏煎 + if(vo.statePump == 0){ + vo.statePump = (byte)1; + }else{ + vo.statePump = (byte)0; + } + + 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 + 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.alarmDoor = (byte)((b >> 1) & 1) ; + vo.alarmBatteryVolt = (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.stateOpClValve = (byte)((b >> 7) & 1) ; + + b = bs[index + 2] ; + vo.alarmBlockValve = (byte)(b & 0x1) ; } public static String parseTp(byte[] bs, short index){ @@ -149,7 +162,7 @@ index += 5 ; Long moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ; - cdData.moneyRemain = moneyRemain/100.0D; + cdData.moneyRemain = moneyRemain/10000.0D; index += 5 ; Long waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ; @@ -165,7 +178,7 @@ index += 4 ; int thisMoney = ByteUtil.BCD2Int_LE(bs, index, index + 3) ; - cdData.thisMoney = thisMoney/100.0D; + cdData.thisMoney = thisMoney/10000.0D; index += 4 ; cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ; @@ -237,7 +250,9 @@ cdData.projectNo = (int)bs[index]; index ++ ; - cdData.opType = bs[index]; + cdData.clType = bs[index]; + //杩涜鍏煎杞崲 + cdData.clType = CommonV202404.closeType2P206V1(cdData.clType) ; index++ ; cdData.icCardAddr = ByteUtil.bytes2Hex(bs, false, index, 4) ; @@ -261,7 +276,7 @@ cdData.eleTotalAmount = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ; index += 5 ; - cdData.moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ; + cdData.moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/10000.0D ; index += 5 ; cdData.waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4)/100.0D ; @@ -273,13 +288,17 @@ cdData.thisWater = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ; index += 4 ; - cdData.thisMoney = ByteUtil.BCD2Long_LE(bs, index, index + 3)/100.0D ; + cdData.thisMoney = ByteUtil.BCD2Long_LE(bs, index, index + 3)/10000.0D ; index += 4 ; cdData.thisDuration = ByteUtil.BCD2Int_LE(bs, index, index + 1) ; index += 2 ; GlParse.parseAlarmAndState(bs, index, cdData) ;//鍥涗釜瀛楄妭 + + index += 4 ; + cdData.price = ByteUtil.BCD2Int_LE(bs, index, index + 1)/100.0 ; + } /** * 鍒嗘瀽鍔熻兘93銆丄3鏁版嵁 @@ -295,10 +314,10 @@ cdData.projectNo = (int)bs[index]; index ++ ; - cdData.opResult = bs[index]; + cdData.clResult = bs[index]; index ++ ; - cdData.opType = bs[index]; + cdData.clType = bs[index]; index++ ; cdData.icCardAddr = ByteUtil.bytes2Hex(bs, false, index, 4) ; @@ -312,7 +331,7 @@ index += 8 ; cdData.startDt = GlParse.parseRtuDt(bs, index) ; - if(cdData.opResult == (byte)0x81){ + if(cdData.clResult == (byte)0x81){ //澶辫触浜嗭紝涓嬮潰灏辨病鏈夋暟鎹簡 return ; } -- Gitblit v1.8.0