From 184980deb3f854a98eb112e7998875113ebbba9a Mon Sep 17 00:00:00 2001
From: lsh <lsh@163.com>
Date: 星期一, 28 四月 2025 17:10:39 +0800
Subject: [PATCH] *

---
 src/main/java/com/zy/core/thread/ScaleThread.java |   56 +++++++++++++++++++++++++++++++++++++++++---------------
 1 files changed, 41 insertions(+), 15 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/ScaleThread.java b/src/main/java/com/zy/core/thread/ScaleThread.java
index 0dcae31..2b7e65d 100644
--- a/src/main/java/com/zy/core/thread/ScaleThread.java
+++ b/src/main/java/com/zy/core/thread/ScaleThread.java
@@ -7,9 +7,13 @@
 import com.zy.asrs.entity.BasDevp;
 import com.zy.asrs.service.BasDevpService;
 import com.zy.asrs.service.DeviceErrorService;
+import com.zy.core.DevpThread;
 import com.zy.core.Slave;
 import com.zy.core.ThreadHandler;
 import com.zy.core.cache.OutputQueue;
+import com.zy.core.cache.SlaveConnection;
+import com.zy.core.enums.SlaveType;
+import com.zy.core.model.protocol.StaProtocol;
 import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
@@ -52,25 +56,47 @@
                     if (!Cools.isEmpty(s) && s.startsWith("=")) {
                         scale = Double.parseDouble(s.substring(1));
 
+//                        String substring = s.substring(1);
+//                        String s1 = new StringBuilder(substring).reverse().toString();//閫嗗簭
+//                        scale = Double.parseDouble(s1);
                         //灏嗙О閲嶉噸閲忓啓鍏ヨ澶囧熀纭�鏁版嵁涓殑gross_wt瀛楁
                         if(scale > 20) {
-                            BasDevpService basDevpService = SpringUtils.getBean(BasDevpService.class);
-                            Integer staNo = slave.getId() == 1 ? 101 : 201;
-                            BasDevp basDevp = basDevpService.selectById(staNo);
-                            if(!Cools.isEmpty(basDevp)) {
-                                basDevp.setGrossWt(scale);
-                                if (null != basDevpService && !basDevpService.updateById(basDevp)) {
-                                    throw new Exception("鏇存柊鏁版嵁搴撴暟鎹け璐�");
+                            try{
+                                // 鑾峰彇绔欎俊鎭�
+                                DevpThread devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, slave.getDevpPlcId());
+                                StaProtocol staProtocol = devpThread.getStation().get(slave.getStaNo());
+                                if (staProtocol != null) {
+                                    devpThread.setGrossWt(staProtocol.getSiteId(), scale);
+
+                                    JSONObject jsonObject = new JSONObject();
+                                    jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F));
+                                    jsonObject.put("id", slave.getStaNo());
+                                    jsonObject.put("scale", scale);
+                                    if (OutputQueue.SCALE.size() >= 32) {
+                                        OutputQueue.SCALE.poll();
+                                    }
+                                    OutputQueue.SCALE.offer(jsonObject);
                                 }
-                                JSONObject jsonObject = new JSONObject();
-                                jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F));
-                                jsonObject.put("id", staNo);
-                                jsonObject.put("scale", scale);
-                                if (OutputQueue.SCALE.size() >= 32) {
-                                    OutputQueue.SCALE.poll();
-                                }
-                                OutputQueue.SCALE.offer(jsonObject);
+                            } catch (Exception e){
+                                log.error("绉伴噸妯″潡寮傚父"+e.getMessage());
                             }
+//                            BasDevpService basDevpService = SpringUtils.getBean(BasDevpService.class);
+//                            BasDevp basDevp = basDevpService.selectById(slave.getStaNo());
+//                            if(!Cools.isEmpty(basDevp)) {
+//                                basDevp.setGrossWt(scale);
+//                                if (null != basDevpService && !basDevpService.updateById(basDevp)) {
+//                                    throw new Exception("鏇存柊鏁版嵁搴撴暟鎹け璐�");
+//                                }
+//                                JSONObject jsonObject = new JSONObject();
+//                                jsonObject.put("time", DateUtils.convert(new Date(), DateUtils.yyyyMMddHHmmss_F));
+//                                jsonObject.put("id", slave.getStaNo());
+//                                jsonObject.put("scale", scale);
+//                                if (OutputQueue.SCALE.size() >= 32) {
+//                                    OutputQueue.SCALE.poll();
+//                                }
+//                                OutputQueue.SCALE.offer(jsonObject);
+//
+//                            }
                         }
                     }
                 }

--
Gitblit v1.9.1