|  |  |  | 
|---|
|  |  |  | import com.dy.common.mw.protocol.*; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.*; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.parse.global.GlParse; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.upVos.DataCd5BVo; | 
|---|
|  |  |  | import com.dy.common.mw.protocol.p206V202404.upVos.DataCd65Vo; | 
|---|
|  |  |  | import com.dy.common.util.ByteUtil; | 
|---|
|  |  |  | import org.apache.logging.log4j.LogManager; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public MidResult[] parse(Boolean isLowPower, CodeParseParams params, CodeParseCallback callback)throws Exception { | 
|---|
|  |  |  | ParseParamsForUpV202404 para = (ParseParamsForUpV202404)params ; | 
|---|
|  |  |  | int bsLen = new CommonV202404().parseDataLen(para.upBuffer) ; | 
|---|
|  |  |  | int bsLen = new CommonV202404().parseDataLen4P202404(para.upBuffer) ; | 
|---|
|  |  |  | if(bsLen > 0){ | 
|---|
|  |  |  | this.doParse(para.upBuffer, | 
|---|
|  |  |  | bsLen, | 
|---|
|  |  |  | para.upCode, | 
|---|
|  |  |  | para.data) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | log.info("分析上行数据<" + CodeV202404.getCodeName(para.upCode) + " RTU地址=" + para.rtuAddr + ">:\n" + para.data.toString()); | 
|---|
|  |  |  | log.info("\n分析命令应答数据<" + CodeV202404.getCodeName(para.upCode) + " RTU地址=" + para.rtuAddr + ">:\n" + para.data.toString()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | MidResultFromRtu midRs = new MidResultFromRtu() ; | 
|---|
|  |  |  | midRs.protocolName = para.protocolName ;//协议名称 | 
|---|
|  |  |  | midRs.protocolVersion = para.protocolVersion ;//协议版本号 | 
|---|
|  |  |  | midRs.rtuAddr = para.rtuAddr ;//Rtu地址 | 
|---|
|  |  |  | midRs.upCode = para.upCode ;//上行数据中的功能码 | 
|---|
|  |  |  | midRs.upHex = para.upHex ;//上行数据十六进制形式 | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | midRs.reportOrResponse_trueOrFalse = false ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | callback.callback(midRs.reportOrResponse_trueOrFalse); | 
|---|
|  |  |  | callback.callback(midRs.reportOrResponse_trueOrFalse, para.data.subData==null?null:((DataV202404)(para.data.subData)).subData); | 
|---|
|  |  |  | return new MidResult[]{midRs} ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | /** | 
|---|
|  |  |  | 
|---|
|  |  |  | * @throws Exception 异常 | 
|---|
|  |  |  | */ | 
|---|
|  |  |  | protected void doParse(byte[] bs, int bsLen, String dataCode, Data data) throws Exception { | 
|---|
|  |  |  | DataV202404 dV1 = (DataV202404)data.getSubData() ; | 
|---|
|  |  |  | DataV202404 dV202404 = (DataV202404)data.getSubData() ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | int index = ProtocolConstantV206V202404.dataIndex ; | 
|---|
|  |  |  | String controllerType = ByteUtil.bytes2Hex(bs, false, index, 1) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | Integer projectNo = 0 + bs[index]; | 
|---|
|  |  |  | Integer projectNo = (int)bs[index]; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | byte hasRecord = bs[index]; | 
|---|
|  |  |  | if(hasRecord == 1){ | 
|---|
|  |  |  | //有记录 | 
|---|
|  |  |  | List<DataCd65Vo> list = new ArrayList<>() ; | 
|---|
|  |  |  | DataCd65Vo vo = this.doParseData(bs, index, bsLen, controllerType, projectNo) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | DataCd65Vo vo = this.doParseData(bs, index, bsLen, dataCode, controllerType, projectNo) ; | 
|---|
|  |  |  | while(vo != null){ | 
|---|
|  |  |  | index += 39 ; | 
|---|
|  |  |  | index += 43 ; | 
|---|
|  |  |  | list.add(vo) ; | 
|---|
|  |  |  | vo = this.doParseData(bs, index, bsLen, controllerType, projectNo) ; | 
|---|
|  |  |  | vo = this.doParseData(bs, index, bsLen, dataCode, controllerType, projectNo) ; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | dV1.subData = list ; | 
|---|
|  |  |  | dV202404.subData = list ; | 
|---|
|  |  |  | }else{ | 
|---|
|  |  |  | //无记录 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | private DataCd65Vo doParseData(byte[] bs, int index, int bsLen, String controllerType,Integer projectNo) throws Exception{ | 
|---|
|  |  |  | //每条数据占39字节 | 
|---|
|  |  |  | if(bsLen - index > 39){ | 
|---|
|  |  |  | DataCd65Vo cdData = new DataCd65Vo() ; | 
|---|
|  |  |  | private DataCd65Vo doParseData(byte[] bs, int index, int bsLen, String dataCode, String controllerType,Integer projectNo) throws Exception{ | 
|---|
|  |  |  | //每条数据占43字节 | 
|---|
|  |  |  | if(bsLen - index > 43){ | 
|---|
|  |  |  | DataCd65Vo cdData = new DataCd65Vo(CodeV202404.getCodeName(dataCode)) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | cdData.controllerType = controllerType ; | 
|---|
|  |  |  | cdData.projectNo = projectNo ; | 
|---|
|  |  |  | 
|---|
|  |  |  | cdData.icCardNo  = GlParse.parseIcCardNo(bs, index, 6, 2) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index += 8 ; | 
|---|
|  |  |  | int moneyRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4) ; | 
|---|
|  |  |  | Long moneyRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ; | 
|---|
|  |  |  | cdData.moneyRemain = moneyRemain/100.0D; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index += 5 ; | 
|---|
|  |  |  | int waterRemain = ByteUtil.BCD2Int_BE(bs, index, index + 4) ; | 
|---|
|  |  |  | Long waterRemain = ByteUtil.BCD2Long_LE(bs, index, index + 4) ; | 
|---|
|  |  |  | cdData.waterRemain = waterRemain/100.0D; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index += 5 ; | 
|---|
|  |  |  | int thisEle = ByteUtil.BCD2Int_BE(bs, index, index + 3) ; | 
|---|
|  |  |  | int thisEle = ByteUtil.BCD2Int_LE(bs, index, index + 3) ; | 
|---|
|  |  |  | cdData.thisEle = thisEle/100.0D; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index += 4 ; | 
|---|
|  |  |  | int thisWater = ByteUtil.BCD2Int_BE(bs, index, index + 3) ; | 
|---|
|  |  |  | int thisWater = ByteUtil.BCD2Int_LE(bs, index, index + 3) ; | 
|---|
|  |  |  | cdData.thisWater = thisWater/100.0D; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index += 4 ; | 
|---|
|  |  |  | String mm = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | String HH = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | String dd = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | String MM = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | cdData.rtuStartDt = MM + "-" + dd + " " + HH + ":" + mm ; | 
|---|
|  |  |  | cdData.rtuStartDt = GlParse.parseRtuDt(bs, index) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | mm = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | HH = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | dd = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | MM = ByteUtil.BCD2String_BE(bs, index, index) ; | 
|---|
|  |  |  | cdData.rtuEndDt = MM + "-" + dd + " " + HH + ":" + mm ; | 
|---|
|  |  |  | index += 6 ; | 
|---|
|  |  |  | cdData.rtuEndDt = GlParse.parseRtuDt(bs, index) ; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | index++ ; | 
|---|
|  |  |  | index += 6 ; | 
|---|
|  |  |  | cdData.useWaterType = bs[index]; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return cdData ; | 
|---|