From 9a139b15be65dcd83ae187bb384627097c6a811a Mon Sep 17 00:00:00 2001 From: vince <757871790@qq.com> Date: 星期二, 26 十二月 2023 20:29:16 +0800 Subject: [PATCH] 修改解析,增加仓温仓湿度 --- src/main/java/com/fzzy/protocol/youxian0/analysis/AnalysisService.java | 109 ++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 69 insertions(+), 40 deletions(-) diff --git a/src/main/java/com/fzzy/protocol/youxian0/analysis/AnalysisService.java b/src/main/java/com/fzzy/protocol/youxian0/analysis/AnalysisService.java index fd3b52b..bab4d2e 100644 --- a/src/main/java/com/fzzy/protocol/youxian0/analysis/AnalysisService.java +++ b/src/main/java/com/fzzy/protocol/youxian0/analysis/AnalysisService.java @@ -80,27 +80,52 @@ if (ServiceUtils.FUNCTION_66.equalsIgnoreCase(funId)) { log.info("---------寮�濮嬭В鏋愮伯鎯呬俊鎭�---------"); - this.analysisGrainStep1(device, msgId, strMsg); + try{ + this.analysisGrainStep1(device, msgId, strMsg); + }catch (Exception e){ + log.error(e.getMessage(),e); + } + + log.info("---------瑙f瀽绮儏淇℃伅缁撴潫---------"); } //娓╂箍搴﹁繑鍥� if (ServiceUtils.FUNCTION_68.equalsIgnoreCase(funId)) { log.info("---------寮�濮嬭В鏋愪粨娓╂箍搴︿俊鎭�---------"); - this.analysisGrainTh(device, strMsg); + try{ + this.analysisGrainTh(device, strMsg); + }catch (Exception e){ + log.error(e.getMessage(),e); + } + } } private void analysisGrainTh(GatewayDevice device, String strMsg) { - THDto th = new THDto(); + try{ + THDto th = new THDto(); - //TODO----->>> 寰呰В鏋愯皟鏁达紝鍏堢敤澶栭儴姘旇薄淇℃伅 - //绯荤粺姘旇薄绔欎俊鎭� - WeatherWebDto weather = WeatherWebDto.contextMap.get("default"); - th.setTempIn(Double.valueOf(weather.getTem()) - 1); - th.setHumidityIn(Double.valueOf(weather.getHumidity()) - 1); + //TODO----->>> 寰呰В鏋愯皟鏁达紝鍏堢敤澶栭儴姘旇薄淇℃伅 + //7E 00 01 01 00 06 00 00 A0 FF FF 68 1A 05 CC 16 3A 62 36 7E + //绯荤粺姘旇薄绔欎俊鎭� +// WeatherWebDto weather = WeatherWebDto.contextMap.get("default"); +// th.setTempIn(Double.valueOf(weather.getTem()) - 2); +// th.setHumidityIn(Double.valueOf(weather.getHumidity()) - 10); + double t,h; + String temp = strMsg.substring(30,32); + t = BytesUtil.hexToInt(temp)/2; + log.info("娓╁害锛歿}",t); + temp = strMsg.substring(32,34); + h = BytesUtil.hexToInt(temp); + log.info("婀垮害锛歿}",h); + th.setTempIn(t); + th.setHumidityIn(h); + this.add2ThMap(device.getDepotIdSys(), th); + }catch (Exception e){ + log.error(e.getMessage(),e); + } - this.add2ThMap(device.getDepotIdSys(), th); } @@ -114,53 +139,57 @@ * @param msgId 鍛戒护ID */ private void analysisGrainStep1(GatewayDevice device, int msgId, String strMsg) { - + String[] attCable = device.getCableRule().split("-"); + int cableZ = Integer.valueOf(attCable[0]); + int cableY = Integer.valueOf(attCable[1]); + int cableX = Integer.valueOf(attCable[2]); + log.info("z={},x={},y={}",cableZ,cableX,cableY); //鑾峰彇璇锋眰淇℃伅 BaseReqData reqData = ProtocolUtils.getSyncReq(device.getDepotIdSys()); if (null == reqData) { log.error("---------娌℃湁鑾峰彇鍒拌姹備俊鎭紝涓嶆墽琛岃В鏋�------{}", device.getDeviceName()); return; } - //鍙繚鐣欑伯鎯呬俊鎭� - int start = 22 * 2; + int start = 15 * 2; strMsg = strMsg.substring(start); - - //瀵嗛挜鍜岀偣鏁� - String kyeNumHex = strMsg.substring(2, 4); - String kyeNumBin = BytesUtil.toBinary8String(BytesUtil.hexToInt(kyeNumHex)); - - String key = "00000" + kyeNumBin.substring(0, 3); - int keyValue = BytesUtil.hexToInt(BytesUtil.bin2Hex(key)); - key = "0000" + kyeNumBin.substring(4); - int numValue = BytesUtil.hexToInt(BytesUtil.bin2Hex(key)); - - //02 A4 BB BA BA B4 - start = 2 * 2; - String tempHex; GrainRoot grainRoot = new GrainRoot(); grainRoot.setKey(buildGrainRootKey(device.getDeviceSn(), msgId)); grainRoot.setNum(msgId); - double point = 0; - for (int i = 0; i < numValue; i++) { - start = start + i * 2; - tempHex = strMsg.substring(start, start + 2); - //瀹為檯娓╁害锛濆瘑閽�*瀵嗛挜*37(婧㈠嚭涓烘棤绗﹀彿瀛楄妭)鍐嶅紓鎴栧姞瀵嗗悗鐨勬俯搴�/2銆� - point = this.getGrainTemp(keyValue, tempHex); - log.debug("--------瑙f瀽鍚庣殑娓╁害鐐�----{}---{}", tempHex, point); - grainRoot.getPoints().add(point); - start = 2 * 2; - } + String tempStr = ""; + for (int j = 0;j<cableY;j++){ + tempStr = strMsg.substring(12 * j,12 * j +12); + //瀵嗛挜鍜岀偣鏁� 02 A4 BB BA BA B4 + String kyeNumHex = tempStr.substring(2, 4); + String kyeNumBin = BytesUtil.toBinary8String(BytesUtil.hexToInt(kyeNumHex)); + + String key = "00000" + kyeNumBin.substring(0, 3); + int keyValue = BytesUtil.hexToInt(BytesUtil.bin2Hex(key)); + key = "0000" + kyeNumBin.substring(4); + int numValue = BytesUtil.hexToInt(BytesUtil.bin2Hex(key)); + + //02 A4 BB BA BA B4 + start = 2 * 2; + String tempHex; + + double point = 0; + for (int i = 0; i < numValue; i++) { + start = start + i * 2; + tempHex = tempStr.substring(start, start + 2); + //瀹為檯娓╁害锛濆瘑閽�*瀵嗛挜*37(婧㈠嚭涓烘棤绗﹀彿瀛楄妭)鍐嶅紓鎴栧姞瀵嗗悗鐨勬俯搴�/2銆� + point = this.getGrainTemp(keyValue, tempHex); + log.info("--------瑙f瀽鍚庣殑娓╁害鐐�----{}---{}", tempHex, point); + grainRoot.getPoints().add(point); + start = 2 * 2; + } + } this.add2GrainMap(grainRoot); //鍒ゆ柇鏄笉鏄渶鍚庝竴鍖呮暟鎹紝濡傛灉鏄渶鍚庝竴鍖呮墽琛岃В鏋� - String[] attCable = device.getCableRule().split("-"); - int cableZ = Integer.valueOf(attCable[0]); - int cableY = Integer.valueOf(attCable[1]); - int cableX = Integer.valueOf(attCable[2]); + if (grainRoot.getNum() == cableX) { analysisGrainStep2(reqData, cableZ, cableY, cableX); } @@ -182,7 +211,7 @@ root = this.getGrainRoot(buildGrainRootKey(reqData.getDevice().getDeviceSn(), i)); if (null == root || null == root.getPoints()) { - log.error("-----------瑙f瀽鑾峰彇鎵�鏈夌伯鎯呮娴嬬偣澶辫触锛屽彇娑堟墽琛�---------{}", reqData.getDevice().getDeviceName()); + log.error("-----------瑙f瀽鑾峰彇鎵�鏈夌伯鎯呮娴嬬偣澶辫触锛屽彇娑堟墽琛�---------{}---{}", reqData.getDevice().getDeviceName(),i); return; } points.addAll(root.getPoints()); -- Gitblit v1.9.3