From 397738b8c9cc5d5d89a962b1b5073fe201ebe680 Mon Sep 17 00:00:00 2001 From: vince <757871790@qq.com> Date: 星期三, 08 十一月 2023 11:21:46 +0800 Subject: [PATCH] 地磅推送 --- src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java | 64 +++++++++++++++++++++++++++++++ 1 files changed, 63 insertions(+), 1 deletions(-) diff --git a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java index 1fe57e0..5e9b45c 100644 --- a/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java +++ b/src/main/java/com/fzzy/gateway/service/GatewayDeviceService.java @@ -1,9 +1,11 @@ package com.fzzy.gateway.service; +import com.alibaba.fastjson.JSON; import com.alibaba.fastjson2.JSONObject; import com.bstek.dorado.annotation.DataProvider; import com.bstek.dorado.annotation.DataResolver; import com.bstek.dorado.annotation.Expose; +import com.fzzy.api.data.GatewayDeviceType; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.utils.DateUtil; import com.fzzy.async.fzzy40.Fzzy40CommonService; @@ -14,8 +16,10 @@ import com.fzzy.gateway.entity.GatewayDevice; import com.fzzy.gateway.hx2023.ScConstant; import com.fzzy.gateway.hx2023.data.*; +import com.fzzy.gateway.hx2023.websocket.WebSocketDeviceReport; import com.fzzy.gateway.service.repository.GatewayDeviceRep; +import com.fzzy.mqtt.MqttPublishService; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; @@ -30,6 +34,7 @@ import java.util.Date; import java.util.List; import java.util.Map; +import java.util.stream.Collectors; @Slf4j @Component @@ -41,7 +46,8 @@ private Fzzy40CommonService fzzy40CommonService; @Resource private GatewayRemoteManager gatewayRemoteManager; - + @Resource + private MqttPublishService mqttPublishService; /** * gatewayDeviceService#listAll * @@ -112,6 +118,62 @@ } + + /** + * gatewayDeviceService#ajaxTestWeight + * 鍦扮鎺ㄩ�佹祴璇� + * + * @param parameter + * @return + */ + @Expose + public String ajaxTestWeight() { + //double weigh = (double) parameter.get("weight"); + double weigh = Double.parseDouble("3500.0"); + List<GatewayDevice> devices = listAll(); + if(devices == null || devices.size()<= 0){ + return "娌℃湁璁惧"; + } + List<GatewayDevice> weights = devices.stream().filter(s ->(GatewayDeviceType.TYPE_01.getCode().equals(s.getType()))).collect(Collectors.toList()); + if(weights == null || weights.size()<= 0){ + return "娌℃湁鑾峰彇鍒板湴纾呰澶�"; + } + String topic = "/device/hx-weigh-big-01/91511424746940066Y001_91511424746940066Y0010000_002_004_002_001/message/property/report"; + + for (GatewayDevice device: weights) { + + WebSocketPacket packet = new WebSocketPacket(); + + //productId鐨勫�煎湪webSocket鎵ц鍙戦�佹柟娉曚腑琛ュ厖 + WebSocketPacketHeader header = new WebSocketPacketHeader(); + header.setDeviceName(device.getDeviceName()); + header.setProductId("hx-weigh-big-01"); + //header.set + packet.setHeaders(header); + packet.setMessageType(ScConstant.MESSAGE_TYPE_REPORT_PROPERTY); + packet.setDeviceId(device.getDeviceId()); + + //璁剧疆淇℃伅涓讳綋 + WeightInfo weightInfo = new WeightInfo(); + weightInfo.setGrossWeight(weigh); + weightInfo.setNetWeight(weigh); + weightInfo.setNetWeight(weigh); + weightInfo.setWeightUnit("KG"); + JSONObject jsonObject = new JSONObject(); + jsonObject.put("weightInfo", JSONObject.toJSONString(weightInfo)); + + packet.setProperties(jsonObject); + + packet.setTimestamp(System.currentTimeMillis()); + + topic = "/device/hx-weigh-big-01/"+device.getDeviceId()+"/message/property/report"; + mqttPublishService.publishMsg(topic, JSON.toJSONString(packet)); + } + return "SUCCESS"; + } + + + /** * gatewayDeviceService#ajaxTestGrain * 绮儏鎺ㄩ�佹祴璇� -- Gitblit v1.9.3