From 0df6e7bb33c9f6a18f026a500776b00cbf2ae62c Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期二, 24 十二月 2024 09:48:06 +0800
Subject: [PATCH] #

---
 src/main/java/com/zy/core/thread/NyShuttleThread.java |   71 +++++++++++++----------------------
 1 files changed, 26 insertions(+), 45 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/NyShuttleThread.java b/src/main/java/com/zy/core/thread/NyShuttleThread.java
index 74450cf..f7dc6fe 100644
--- a/src/main/java/com/zy/core/thread/NyShuttleThread.java
+++ b/src/main/java/com/zy/core/thread/NyShuttleThread.java
@@ -172,6 +172,8 @@
                 shuttleProtocol.setStatusSum(jsonObject.getObject("statusSum", NyShuttleProtocol.StatusSumClass.class));
                 //闈炶嚜鍔ㄧ姸鎬佹椂闂磋鏃�
                 shuttleProtocol.setErrTime(jsonObject.getInteger("errTime"));
+                //鏈�杩戜竴娆″湪绾挎椂闂�
+                shuttleProtocol.setLastOnlineTime(System.currentTimeMillis());
 
                 //灏忚溅澶勪簬杩愯涓紝灏嗘爣璁扮疆涓篺alse
                 if (shuttleProtocol.getFree() == 0) {
@@ -187,56 +189,13 @@
                     basShuttle.setShuttleNo(slave.getId());
                     shuttleService.insert(basShuttle);
                 }
-                //宸ヤ綔妯″紡
-                basShuttle.setWorkingMode(shuttleProtocol.getWorkingMode());
-                //杩愯鐘舵��
-                basShuttle.setFree(shuttleProtocol.getFree());
-                //褰撳墠閫熷害
-                basShuttle.setSpeed(shuttleProtocol.getSpeed());
-                //璐熻浇鐘舵��
-                basShuttle.setLoadState(shuttleProtocol.getLoadState());
-                //绠″埗鐘舵��
-                basShuttle.setSuspendState(shuttleProtocol.getSuspendState());
-                //椤跺崌浣嶇疆
-                basShuttle.setLiftPosition(shuttleProtocol.getLiftPosition());
-                //杩愯鏂瑰悜
-                basShuttle.setRunDir(shuttleProtocol.getRunDir());
-                //杩愯鏂瑰悜
-                basShuttle.setRunDir2(shuttleProtocol.getRunDir2());
-                //鍏呯數鐘舵��
-                basShuttle.setChargState(shuttleProtocol.getChargState());
-                //鐢垫睜鐢甸噺
-                basShuttle.setPowerPercent(shuttleProtocol.getPowerPercent());
-                //鏈�楂樼數鑺數鍘�
-                basShuttle.setMaxCellVoltage(shuttleProtocol.getMaxCellVoltage());
-                //鐢垫睜鐢靛帇
-                basShuttle.setVoltage(shuttleProtocol.getVoltage());
-                //鍏呮斁鐢靛惊鐜鏁�
-                basShuttle.setChargeCycleTimes(shuttleProtocol.getChargeCycleTimes());
-                //鍓╀綑鐢甸噺
-                basShuttle.setSurplusQuantity(shuttleProtocol.getSurplusQuantity());
-                //鎬荤數閲�
-                basShuttle.setCountQuantity(shuttleProtocol.getCountQuantity());
-                //瀹為檯搴撲綅
-                basShuttle.setPoint(JSONObject.toJSONString(shuttleProtocol.getPoint()));
-                //瀹為檯鍧愭爣
-                basShuttle.setCoord(JSONObject.toJSONString(shuttleProtocol.getCoord()));
-                //浠诲姟鐩殑搴撲綅
-                basShuttle.setTask(JSONObject.toJSONString(shuttleProtocol.getTask()));
-                //浠诲姟鐘舵��
-                basShuttle.setTaskState(shuttleProtocol.getTaskState());
-                //鏁呴殰鐘舵��
-                basShuttle.setErrState(shuttleProtocol.getErrState());
-                //鎬婚噷绋嬫暟
-                basShuttle.setStatusSum(JSONObject.toJSONString(shuttleProtocol.getStatusSum()));
-                //闈炶嚜鍔ㄧ姸鎬佹椂闂磋鏃�
-                basShuttle.setErrTime(shuttleProtocol.getErrTime());
                 //浠诲姟鍙�
                 basShuttle.setWrkNo(shuttleProtocol.getTaskNo().intValue());
                 //淇敼鏃堕棿
                 basShuttle.setUpdateTime(new Date());
                 //浣滀笟鏍囪
                 basShuttle.setPakMk(shuttleProtocol.getPakMk());
+                basShuttle.setDeviceStatus(JSON.toJSONString(basShuttle));
                 if (shuttleService.updateById(basShuttle)) {
                     OutputQueue.SHUTTLE.offer(MessageFormat.format("銆恵0}銆慬id:{1}] <<<<< 瀹炴椂鏁版嵁鏇存柊鎴愬姛",DateUtils.convert(new Date()), slave.getId()));
 //                    log.info(MessageFormat.format("銆恵0}銆慬id:{1}] <<<<< 瀹炴椂鏁版嵁鏇存柊鎴愬姛",DateUtils.convert(new Date()), slave.getId()));
@@ -830,7 +789,7 @@
                     shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1);
                 }
             }
-        } else if (shuttleProtocol.getMoveType() == 2) {//寰幆璺�
+        } else if (shuttleProtocol.getMoveType() == 2) {//姣嶈建閬撳惊鐜窇
             Integer xCurrent = shuttleProtocol.getXCurrent();
             Integer yCurrent = shuttleProtocol.getYCurrent();
 
@@ -852,6 +811,28 @@
                     }
                 }
             }
+        } else if (shuttleProtocol.getMoveType() == 3) {//瀛愯建閬撳惊鐜窇
+            Integer xCurrent = shuttleProtocol.getXCurrent();
+            Integer yCurrent = shuttleProtocol.getYCurrent();
+
+            String locNo = Utils.getLocNo(xCurrent, yCurrent, lev);
+            //璋冨害鍘荤洰鏍囦綅缃�
+            if (shuttleProtocol.getCurrentLocNo().equals(locNo)) {
+                if (xCurrent.equals(shuttleProtocol.getXStart())) {
+                    shuttleProtocol.setXCurrent(shuttleProtocol.getXTarget());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅
+                }else {
+                    shuttleProtocol.setXCurrent(shuttleProtocol.getXStart());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅
+                }
+            } else {
+                boolean result = shuttleDispatchUtils.dispatchShuttle(commonService.getWorkNo(3), locNo);
+                if (result) {//璋冨害鎴愬姛
+                    if (xCurrent.equals(shuttleProtocol.getXStart())) {
+                        shuttleProtocol.setXCurrent(shuttleProtocol.getXTarget());//鍒囨崲搴撲綅
+                    }else {
+                        shuttleProtocol.setXCurrent(shuttleProtocol.getXStart());//鍒囨崲搴撲綅
+                    }
+                }
+            }
         }
     }
 

--
Gitblit v1.9.1