From 96668ab15eb069daf487d128fd091d795b814861 Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期二, 25 七月 2023 08:25:00 +0800
Subject: [PATCH] 捡料

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  679 ++++++++++++++++++-------------------------------------
 1 files changed, 225 insertions(+), 454 deletions(-)

diff --git a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
index 925db77..54bd758 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -261,9 +261,9 @@
                             News.error("璇锋眰鎺ュ彛澶辫触锛侊紒锛乽rl锛歿}锛況equest锛歿}锛況esponse锛歿}", wmsUrl + "/rpc/pakin/loc/v1", JSON.toJSONString(param), response);
                         } else if (code == 700) {
                             staProtocol.setWorkNo((short) 32002);
-                            staProtocol.setStaNo(inSta.getBackSta().shortValue());
+                            staProtocol.setRollback102(1);//102绔欏洖閫�淇″彿
                             devpThread.setPakMk(staProtocol.getSiteId(), false);
-                            MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(2, staProtocol));
+                            MessageQueue.offer(SlaveType.Devp, devp.getId(), new Task(5, staProtocol));
 
                             // led 寮傚父鏄剧ず
                             if (ledThread != null) {
@@ -397,7 +397,6 @@
                 }
                 if (staProtocol.isAutoing()
                         && staProtocol.isLoading()
-                        && staProtocol.isInEnable()
                         // 0 - 9990 鎴栬�� 9996
                         && (staProtocol.getWorkNo() > 0 && staProtocol.getWorkNo() < 9990)
                         && staProtocol.getStaNo().equals(staProtocol.getSiteId().shortValue())
@@ -797,7 +796,7 @@
                                     Short endStartCode = Short.parseShort(basDevp.getQrCodeValue());//绔欑偣浜岀淮鐮�
 
                                     //澧炲姞绉诲姩杩涙彁鍗囨満鍛戒护
-                                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1400, ShuttleRunDirection.TOP.id, null, null, 500);
+                                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1600, ShuttleRunDirection.TOP.id, null, null, 500);
                                     commands.add(moveCommand);
 
                                     //鍒嗛厤鐩爣搴撲綅
@@ -822,7 +821,7 @@
                                 Short distCode = Short.parseShort(basDevp.getQrCodeValue());//鎻愬崌鏈哄彛绔欑偣浜岀淮鐮�
                                 Short runDirection = ShuttleRunDirection.BOTTOM.id;//杩愯鏂瑰悜
                                 //鑾峰彇鍛戒护
-                                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1400, runDirection, null, null, 500);
+                                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1600, runDirection, null, null, 500);
                                 commands.add(0, moveCommand);//灏嗚鎸囦护娣诲姞鍒伴槦澶�
 
                                 assignCommand.setCommands(commands);
@@ -849,7 +848,7 @@
 //                                    Short distCode = Short.parseShort(basDevp.getQrCodeValue());//鎻愬崌鏈哄彛绔欑偣浜岀淮鐮�
 //                                    Short runDirection = ShuttleRunDirection.BOTTOM.id;//杩愯鏂瑰悜
 //                                    //鑾峰彇鍛戒护
-//                                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1400, runDirection, startCode, 1400, 500);
+//                                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1600, runDirection, startCode, 1600, 500);
 //                                    commands.add(0, moveCommand);//灏嗚鎸囦护娣诲姞鍒伴槦澶�
 //                                }
 //                                assignCommand.setCommands(commands);
@@ -872,7 +871,7 @@
 //                                Short endStartCode = Short.parseShort(basDevp.getQrCodeValue());//绔欑偣浜岀淮鐮�
 //
 //                                //澧炲姞绉诲姩杩涙彁鍗囨満鍛戒护
-//                                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1400, ShuttleRunDirection.TOP.id, endStartCode, 1400, 500);
+//                                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1600, ShuttleRunDirection.TOP.id, endStartCode, 1600, 500);
 //                                commands.add(moveCommand);
 //
 //                                //鍒嗛厤鐩爣搴撲綅
@@ -938,13 +937,13 @@
                 middlePath = nodes.get(nodes.size() - 3);
                 //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                 middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
             } else if (nodes.size() > 5) {//涓鐮佷紶鍊掓暟绗簩涓�
                 //涓棿璺緞
                 middlePath = nodes.get(nodes.size() - 2);
                 //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                 middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
             }
 
             //鐩爣璺緞
@@ -1008,13 +1007,13 @@
                     middlePath = nodes.get(nodes.size() - 3);
                     //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                     middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                    middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                    middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
                 } else if (nodes.size() > 5) {//涓鐮佷紶鍊掓暟绗簩涓�
                     //涓棿璺緞
                     middlePath = nodes.get(nodes.size() - 2);
                     //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                     middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                    middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                    middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
                 }
 
                 //鐩爣璺緞
@@ -1060,13 +1059,13 @@
                 middlePath = nodes.get(nodes.size() - 3);
                 //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                 middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
             } else if (nodes.size() > 5) {//涓鐮佷紶鍊掓暟绗簩涓�
                 //涓棿璺緞
                 middlePath = nodes.get(nodes.size() - 2);
                 //閫氳繃xy鍧愭爣灏忚溅浜岀淮鐮�
                 middleCodeNum = NavigatePositionConvert.xyToPosition(middlePath.getX(), middlePath.getY(), middlePath.getZ());
-                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
+                middleToDistDistance = NavigateUtils.getMiddleToDistDistance(nodes, middlePath);//璁$畻涓棿鐐瑰埌鐩爣鐐硅璧拌窛绂�
             }
 
             //鐩爣璺緞
@@ -1262,7 +1261,7 @@
                             Short endStartCode = Short.parseShort(basDevp.getQrCodeValue());//绔欑偣浜岀淮鐮�
 
                             //澧炲姞绉诲姩杩涙彁鍗囨満鍛戒护
-                            ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1400, ShuttleRunDirection.TOP.id, null, null, 500);
+                            ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1600, ShuttleRunDirection.TOP.id, null, null, 500);
                             commands.add(moveCommand);
 
                             //鐩爣搴撲綅
@@ -1303,7 +1302,7 @@
                         short startCode = liftProtocol.getBarcode();//鎻愬崌鏈哄唴閮ㄤ簩缁寸爜
                         Short distCode = commands.get(0).getStartCodeNum();//鐩爣浜岀淮鐮�
                         //鑾峰彇绉诲姩鍛戒护
-                        ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1400, commands.get(0).getRunDirection(), null, null, 500);
+                        ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1600, commands.get(0).getRunDirection(), null, null, 500);
                         commands.add(0, moveCommand);//灏嗚鎸囦护娣诲姞鍒伴槦澶�
 
                         //鍒嗛厤鐩爣搴撲綅
@@ -1343,12 +1342,15 @@
 
         //鍒ゆ柇鍏朵粬绌洪棽绌挎杞︽槸鍚︾浠诲姟鏈�杩�
         String distLocNo = null;//鐩爣鍦扮偣锛屽叆搴�=銆嬫彁鍗囨満鍙o紝鍑哄簱=銆嬭揣鐗╁簱浣嶅彿
-        if (wrkMast.getIoType() < 101) {
+        if (wrkMast.getIoType() == 1 || wrkMast.getIoType() == 10) {
             //鍏ュ簱
             distLocNo = Utils.levToOutInStaLocNo(lev);
-        }else {
+        }else if(wrkMast.getIoType() == 101 || wrkMast.getIoType() == 103){
             //鍑哄簱
             distLocNo = locNo;
+        } else if (wrkMast.getIoType() == 11) {
+            //搴撲綅绉昏浆
+            distLocNo = wrkMast.getSourceLocNo();
         }
 
         //鍒ゆ柇褰撳墠浠诲姟鎵�鍦ㄦゼ灞傛槸鍚︽湁鍏朵粬浠诲姟宸茬粡鍒嗛厤浜嗗皬杞︼紝濡傛湁鍒欑洿鎺ョ敤璇ュ皬杞�(涓�灞傛ゼ浠呭垎閰嶄竴鍙拌溅)
@@ -1827,12 +1829,13 @@
                     LiftCommand command2 = liftThread.getLiftTurnCommand(liftProtocol.getLiftNo(), liftProtocol.getTaskNo(), 4);
                     command2.setOperaStaNo(staProtocol.getSiteId().shortValue());//杈撻�佺嚎鎿嶄綔绔欑偣鍙�
                     command2.setRotationDire(2);//缁欒緭閫佺嚎涓嬪彂閾炬潯杞姩淇″彿锛屽弽杞�
-                    command2.setDevpId(devpId);//杈撻�佺嚎iD
+                    command2.setDevpId(devpId);//杈撻�佺嚎ID
                     command2.setStaNo((short) 104);//鍐欏叆鍑哄簱鐩爣绔�104
                     commands.add(command2);//灏嗗懡浠ゆ坊鍔犺繘list
 
                     //鎻愬崌鏈哄墠寰�鍑哄簱鍙o紝杈撻�佺嚎妤煎眰
                     LiftCommand command3 = liftThread.getLiftUpDownCommand(liftProtocol.getLiftNo(), liftProtocol.getTaskNo(), LiftLevType.TWO.lev);
+                    command3.setDevpId(devpId);//杈撻�佺嚎ID
                     commands.add(command3);//灏嗗懡浠ゆ坊鍔犺繘list
 
                     //鎻愬崌鏈哄埌杈炬寚瀹氭ゼ灞傦紝杈撻�佺嚎灏嗚揣鐗╃Щ鍑哄幓(鍙嶈浆)
@@ -1840,12 +1843,12 @@
                     LiftCommand command4 = liftThread.getLiftTurnCommand(liftProtocol.getLiftNo(), liftProtocol.getTaskNo(), 2);
                     command4.setOperaStaNo((short) 102);//鎿嶄綔102绔�
                     command4.setRotationDire(2);//缁欒緭閫佺嚎涓嬪彂閾炬潯杞姩淇″彿锛屽弽杞�
-                    command4.setDevpId(devpId);
+                    command4.setDevpId(devpId);//杈撻�佺嚎ID
                     commands.add(command4);//灏嗗懡浠ゆ坊鍔犺繘list
 
                     //鎻愬崌鏈洪摼鏉℃墽琛屽畬姣曞悗锛岀粰102绔欏啓鍏ヨ祫鏂�
                     LiftCommand command5 = liftThread.getResetCommand();
-                    command5.setDevpId(devpId);//杈撻�佺嚎iD
+                    command5.setDevpId(devpId);//杈撻�佺嚎ID
                     command5.setOperaStaNo((short) 102);//鎿嶄綔102绔�
                     command5.setStaNo((short) 104);//鍐欏叆鍑哄簱鐩爣绔�104
                     command5.setRotationDire(0);//閾炬潯杞姩鍋滄
@@ -2012,285 +2015,229 @@
     }
 
     /**
-     * 褰撳墠搴撲綅缁勬槸鍚﹀瓨鍦ㄧ┖闂插皬杞�
+     * 搴撲綅绉昏浆
      */
-    public Integer hasCar(String locNo) {
-        for (SteSlave ste : slaveProperties.getSte()) {
-            // 鑾峰彇鍫嗗灈鏈轰俊鎭�
-            SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, ste.getId());
-            SteProtocol steProtocol = steThread.getSteProtocol();
-            BasSte basSte = basSteService.selectById(ste.getId());
-            if (Cools.isEmpty(steProtocol, basSte)) { continue; }
-            if (Utils.getGroupRow(locNo, true).equals(Utils.getGroupRow(basSte.getRow(), true))
-                    && basSte.getBay() == Utils.getBay(locNo)
-                    && basSte.getLev() == Utils.getLev(locNo)) {
-                return ste.getId();
-            }
-        }
-        return null;
-    }
-
-    /**
-     * 褰撳墠搴撲綅缁勬槸鍚﹀瓨鍦ㄥ叾浠栧皬杞�
-     */
-    public Integer existOtherSte(String locNo, Integer steNo) {
-        Integer otherSteNo = null;
-        for (SteSlave ste : slaveProperties.getSte()) {
-            if (ste.getId().equals(steNo)) { continue; }
-            // 鑾峰彇鍫嗗灈鏈轰俊鎭�
-            SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, ste.getId());
-            SteProtocol steProtocol = steThread.getSteProtocol();
-            if (steProtocol == null) { continue; }
-            if (steProtocol.isEnable()) {
-                BasSte basSte = basSteService.selectById(ste.getId());
-                if (basSte != null) {
-                    if ((Utils.getGroupRow(locNo, true).equals(Utils.getGroupRow(basSte.getRow(), true))
-                            && basSte.getBay() == Utils.getBay(locNo)
-                            && basSte.getLev() == Utils.getLev(locNo))
-                        ||
-                        (Utils.getGroupRow(locNo, true).equals(Utils.getGroupRow(steProtocol.getRow().intValue(), true))
-                                && steProtocol.getBay() == Utils.getBay(locNo)
-                                && steProtocol.getLev() == Utils.getLev(locNo))
-                    ) {
-                        otherSteNo = ste.getId();
-                        break;
-                    }
-                }
-            }
-        }
-        return otherSteNo;
-    }
-
-    /**
-     * 褰撳墠搴撲綅缁勬槸鍚﹀瓨鍦ㄧ┖闂插皬杞�
-     */
-    public Integer hasCarOfIdle(String locNo) {
-        for (SteSlave ste : slaveProperties.getSte()) {
-            // 鑾峰彇鍫嗗灈鏈轰俊鎭�
-            SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, ste.getId());
-            SteProtocol steProtocol = steThread.getSteProtocol();
-            if (steProtocol == null) { continue; }
-            if (steProtocol.isIdle()) {
-                if (Utils.getGroupRow(locNo, true).equals(Utils.getGroupRow(steProtocol.getRow().intValue(), true))
-                        && steProtocol.getBay() == Utils.getBay(locNo)
-                        && steProtocol.getLev() == Utils.getLev(locNo)) {
-                    return steProtocol.getSteNo().intValue();
-                }
-            }
-        }
-        return null;
-    }
-
-    /**
-     * 鏌ユ壘褰撳墠搴撲綅鏈�閫傚悎鐨勭┛姊溅鏉ヤ綔涓�
-     */
-    public SteThread queryIdleCar(WrkMast wrkMast) {
-        List<BasSte> basStes = basSteService.selectList(new EntityWrapper<>());
-        int val = 0;
-        SteThread result = null;
-        for (BasSte basSte : basStes) {
-            // 鑾峰彇绌挎杞︿俊鎭�
-            SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, basSte.getSteNo());
-            SteProtocol steProtocol = steThread.getSteProtocol();
-            if (steProtocol == null) { continue; }
-            if (!steProtocol.isIdle()) { continue; }
-//            if (steProtocol.getRow() == 1) { continue; }
-            String locNo = wrkMast.getWrkSts() < 10 ? wrkMast.getLocNo() : wrkMast.getSourceLocNo();
-            // 濡傛灉鍦ㄥ悓涓�涓簱浣嶇粍
-            if (Utils.getGroupRow(locNo, true).equals(Utils.getGroupRow(steProtocol.getRow().intValue(), true))
-                    && steProtocol.getBay().intValue() == Utils.getBay(locNo)
-                    && steProtocol.getLev().intValue() == Utils.getLev(locNo)) {
-                return steThread;
-            }
-            LocMast locMast = locMastService.selectById(locNo);
-            int lev = locMast.getLev1();
-            int bay = locMast.getBay1();
-            int levAbs = Math.abs(lev - steProtocol.getLev());
-            int bayAbs = Math.abs(bay - steProtocol.getBay());
-            if (val == 0) {
-                val = levAbs + bayAbs;
-                result = steThread;
-            } else {
-                if ((levAbs + bayAbs) < val) {
-                    val = levAbs + bayAbs;
-                    result = steThread;
-                }
-            }
-        }
-        return result;
-    }
-
-    public SteThread queryIdleCar(CrnProtocol crnProtocol) {
-        List<BasSte> basStes = basSteService.selectList(new EntityWrapper<>());
-        int val = 0;
-        SteThread result = null;
-        for (BasSte basSte : basStes) {
-            // 鑾峰彇绌挎杞︿俊鎭�
-            SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, basSte.getSteNo());
-            SteProtocol steProtocol = steThread.getSteProtocol();
-            if (steProtocol == null) { continue; }
-            if (!steProtocol.isIdle()) { continue; }
-            if (steProtocol.getRow() == 1) { continue;}
-            int lev = crnProtocol.getLevel();
-            int bay = crnProtocol.getBay();
-            int levAbs = Math.abs(lev - steProtocol.getLev());
-            int bayAbs = Math.abs(bay - steProtocol.getBay());
-            if (val == 0) {
-                val = levAbs + bayAbs;
-                result = steThread;
-            } else {
-                if ((levAbs + bayAbs) < val) {
-                    val = levAbs + bayAbs;
-                    result = steThread;
-                }
-            }
-        }
-        return result;
-    }
-
-    /**
-     * 璁╁皬杞﹁璧拌嚦寰呮満浣�
-     */
-    public void letCarBeWaiting(WrkMast wrkMast, Integer steNo, String locNo) {
-        // 鑾峰彇绌挎杞︿俊鎭�
-        SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, steNo);
-        SteProtocol steProtocol = steThread.getSteProtocol();
-        if (steProtocol == null) { return; }
-        if (steProtocol.isIdle()) {
-
-            // 濡傛灉澶勪簬寰呮満浣�
-            if (steProtocol.locaType.equals(SteLocaType.A_WAITING) || steProtocol.locaType.equals(SteLocaType.B_WAITING)) {
-                // 淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞�
-                wrkMast.setWrkSts(3L);
-                wrkMast.setSteNo(steNo);
-                wrkMast.setModiTime(new Date());
-                if (wrkMastMapper.updateById(wrkMast) == 0) {
-                    News.error("淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                }
-            } else {
-                // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-                SteCommand steCommand = new SteCommand();
-                steCommand.setSteNo(steNo); // 绌挎杞︾紪鍙�
-                steCommand.setTaskNo(wrkMast.getWrkNo()); // 宸ヤ綔鍙�
-                steCommand.setTaskMode(SteTaskModeType.findWaiting(steProtocol.getRow().intValue())); // 浠诲姟妯″紡:  琛岃蛋鑷冲緟鏈轰綅
-
-                steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue(), true).shortValue());
-                steCommand.setBay(steProtocol.getBay());
-                steCommand.setLev(steProtocol.getLev());
-
-                if (!MessageQueue.offer(SlaveType.Ste, steNo, new Task(2, steCommand))) {
-                    News.error("绌挎杞﹀懡浠や笅鍙戝け璐ワ紝绌挎杞﹀彿={}锛屼换鍔℃暟鎹�={}", steNo, JSON.toJSON(steCommand));
-                } else {
-                    // 淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞�
-                    wrkMast.setSteNo(steNo);
-                    wrkMast.setModiTime(new Date());
-                    if (wrkMastMapper.updateById(wrkMast) == 0) {
-                        News.error("淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                    }
-                }
-            }
-        }
-    }
-
-    public void letCarBeWaiting(WrkCharge wrkCharge, Integer steNo) {
-        // 鑾峰彇绌挎杞︿俊鎭�
-        SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, steNo);
-        SteProtocol steProtocol = steThread.getSteProtocol();
-        if (steProtocol == null) { return; }
-
-        if (!basSteService.updatePakMk(steNo, "Y")) {
-            News.error("淇敼绌挎杞︿綔涓氱姸鎬� 澶辫触锛侊紒锛岀┛姊溅={}", steNo);
+    public synchronized void locToLocExecute() {
+        //鑾峰彇鍑哄叆搴撳伐浣滄。
+        List<WrkMast> wrkMasts = wrkMastMapper.selectInOutWrkMast();
+        if (wrkMasts.size() > 0) {
+            //鏈夊嚭鍏ュ簱浠诲姟锛屽繀椤荤瓑寰呬换鍔℃墽琛屽畬姣曞啀鎵ц搴撲綅绉昏浆
             return;
         }
 
-        // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-        SteCommand steCommand = new SteCommand();
-        steCommand.setSteNo(steNo); // 绌挎杞︾紪鍙�
-        steCommand.setTaskNo(wrkCharge.getWrkNo()); // 宸ヤ綔鍙�
-        steCommand.setTaskMode(SteTaskModeType.findOriginByLoc(steProtocol.getRow().intValue())); // 浠诲姟妯″紡:  鍘昏繎鐐� 绛夊緟鍫嗗灈鏈哄弶鍙�
+        //鏌ヨ搴撲綅绉昏浆宸ヤ綔妗�
+        List<WrkMast> wrkMasts1 = wrkMastMapper.selectLocToLocWrkMast();
+        for (WrkMast wrkMast : wrkMasts1) {
 
-        steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue(), true).shortValue());
-        steCommand.setBay(steProtocol.getBay());
-        steCommand.setLev(steProtocol.getLev());
-
-        if (!MessageQueue.offer(SlaveType.Ste, steNo, new Task(2, steCommand))) {
-            News.error("绌挎杞﹀懡浠や笅鍙戝け璐ワ紝绌挎杞﹀彿={}锛屼换鍔℃暟鎹�={}", steNo, JSON.toJSON(steCommand));
-        } else {
-            // 淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞�
-            wrkCharge.setSteNo(steNo);
-            wrkCharge.setModiTime(new Date());
-            if (!wrkChargeService.updateById(wrkCharge)) {
-                News.error("淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkCharge.getWrkNo());
+            boolean step1 = this.locToLocExecuteStep1(wrkMast);//缁戝畾灏忚溅
+            if (!step1) {
+                continue;
             }
+
+            boolean step2 = this.locToLocExecuteStep2(wrkMast);//璋冨害灏忚溅鍒扮洰鏍囨ゼ灞�
+            if (!step2) {
+                continue;
+            }
+
+            boolean step3 = this.locToLocExecuteStep3(wrkMast);//鍚屾ゼ灞傚簱浣嶇Щ杞�
+            if (!step3) {
+                continue;
+            }
+
         }
     }
 
     /**
-     * 璁╁皬杞︿粠 杩滅偣 ====>> 绉诲姩鍒拌繎鐐�
-     *  绛夊緟鍫嗗灈鏈烘惉杩�
+     * 缁戝畾灏忚溅骞惰皟搴﹁溅
+     * 濡傞渶涓绘柟娉曟墽琛宑ontinue锛岃杩斿洖false
+     * ps:杩斿洖鍊紅rue骞朵笉浠h〃璇ユ柟娉曟墽琛屾垚鍔燂紝杩斿洖鍊间粎鍋氭爣璁扮敤浜庝富鏂规硶鏄惁鎵цcontinue
      */
-    public void letCarBeReady(WrkMast wrkMast, Integer steNo, String locNo) {
-        // 鑾峰彇绌挎杞︿俊鎭�
-        SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, steNo);
-        SteProtocol steProtocol = steThread.getSteProtocol();
-        if (steProtocol == null) { return; }
-        if (steProtocol.isIdle()) {
-
-            // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-            SteCommand steCommand = new SteCommand();
-            steCommand.setSteNo(steNo); // 绌挎杞︾紪鍙�
-            steCommand.setTaskNo(wrkMast.getWrkNo()); // 宸ヤ綔鍙�
-            steCommand.setTaskMode(SteTaskModeType.findOriginByLoc(steProtocol)); // 浠诲姟妯″紡:  鍘昏繎鐐� 绛夊緟鍫嗗灈鏈哄弶鍙�
-
-            steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue(), true).shortValue());
-            steCommand.setBay(steProtocol.getBay());
-            steCommand.setLev(steProtocol.getLev());
-
-            if (!MessageQueue.offer(SlaveType.Ste, steNo, new Task(2, steCommand))) {
-                News.error("绌挎杞﹀懡浠や笅鍙戝け璐ワ紝绌挎杞﹀彿={}锛屼换鍔℃暟鎹�={}", steNo, JSON.toJSON(steCommand));
-            } else {
-                // 淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞�
-                wrkMast.setSteNo(steNo);
-                wrkMast.setModiTime(new Date());
-                if (wrkMastMapper.updateById(wrkMast) == 0) {
-                    News.error("淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkMast.getWrkNo());
-                }
+    private boolean locToLocExecuteStep1(WrkMast wrkMast) {
+        if (wrkMast.getShuttleNo() == null) {//缁欏簱浣嶇Щ杞粦瀹氱┛姊溅鍙�
+            //瀵绘壘鏈�杩戜笖绌洪棽鐨勫洓鍚戠┛姊溅
+            HashMap<String,Object> searchIdleShuttle = this.searchIdleShuttle(wrkMast);
+            ShuttleThread shuttleThread = (ShuttleThread) searchIdleShuttle.get("result");
+            if (shuttleThread == null) {
+                //娌℃湁鎵惧埌绌洪棽绌挎杞�
+                return false;
             }
+            wrkMast.setShuttleNo(shuttleThread.getSlave().getId());//缁欏伐浣滄。鍒嗛厤鍥涘悜绌挎杞﹀彿
+            wrkMastMapper.updateById(wrkMast);
         }
+        return true;
     }
 
     /**
-     * 璁╁皬杞︿粠 杩滅偣 ====>> 绉诲姩鍒拌繎鐐�
-     *  绛夊緟鍫嗗灈鏈烘惉杩�
+     * 璋冨害灏忚溅鍒扮洰鏍囨ゼ灞�
+     * 濡傞渶涓绘柟娉曟墽琛宑ontinue锛岃杩斿洖false
+     * ps:杩斿洖鍊紅rue骞朵笉浠h〃璇ユ柟娉曟墽琛屾垚鍔燂紝杩斿洖鍊间粎鍋氭爣璁扮敤浜庝富鏂规硶鏄惁鎵цcontinue
      */
-    public void letCarBeReady(WrkCharge wrkCharge, Integer steNo) {
-        // 鑾峰彇绌挎杞︿俊鎭�
-        SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, steNo);
-        SteProtocol steProtocol = steThread.getSteProtocol();
-        if (steProtocol == null) { return; }
-        if (steProtocol.isIdle()) {
+    private boolean locToLocExecuteStep2(WrkMast wrkMast) {
+        if (wrkMast.getWrkSts() == 1 && wrkMast.getShuttleNo() != null) {
+            ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, wrkMast.getShuttleNo());
+            ShuttleProtocol shuttleProtocol = shuttleThread.getShuttleProtocol();
+            if (!shuttleProtocol.isIdle(wrkMast.getWrkNo().shortValue())) {
+                return false;//灏忚溅澶勪簬涓嶇┖闂茬姸鎬�
+            }
 
-            // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-            SteCommand steCommand = new SteCommand();
-            steCommand.setSteNo(steNo); // 绌挎杞︾紪鍙�
-            steCommand.setTaskNo(wrkCharge.getWrkNo()); // 宸ヤ綔鍙�
-            steCommand.setTaskMode(SteTaskModeType.findOriginByLoc(steProtocol)); // 浠诲姟妯″紡:  鍘昏繎鐐� 绛夊緟鍫嗗灈鏈哄弶鍙�
+            String currentLocNo = shuttleProtocol.getCurrentLocNo();//灏忚溅褰撳墠搴撲綅鍙�
+            int shuttleLev = Utils.getLev(currentLocNo);//灏忚溅鎵�鍦ㄦゼ灞�
 
-            steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue(), true).shortValue());
-            steCommand.setBay(steProtocol.getBay());
-            steCommand.setLev(steProtocol.getLev());
+            LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, 1);
+            LiftProtocol liftProtocol = liftThread.getLiftProtocol();
 
-            if (!MessageQueue.offer(SlaveType.Ste, steNo, new Task(2, steCommand))) {
-                News.error("绌挎杞﹀懡浠や笅鍙戝け璐ワ紝绌挎杞﹀彿={}锛屼换鍔℃暟鎹�={}", steNo, JSON.toJSON(steCommand));
-            } else {
-                // 淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞�
-                wrkCharge.setSteNo(steNo);
-                wrkCharge.setModiTime(new Date());
-                if (!wrkChargeService.updateById(wrkCharge)) {
-                    News.error("淇敼宸ヤ綔妗g姸鎬� 缁戝畾绌挎杞� 澶辫触锛侊紒锛屽伐浣滃彿={}", wrkCharge.getWrkNo());
+            //鍒ゆ柇灏忚溅鏄惁鍐嶇洰鏍囨ゼ灞�
+            if (shuttleLev != Utils.getLev(wrkMast.getLocNo())) {
+                //灏忚溅鍜岀洰鏍囦笉鍦ㄥ悓涓�妤煎眰
+
+                //鎻愬崌鏈哄彛绔欑偣搴撲綅鍙�
+                String liftSiteLocNo = Utils.levToOutInStaLocNo(shuttleLev);
+
+                //鍒涘缓鍒嗛厤鍛戒护
+                ShuttleAssignCommand assignCommand = new ShuttleAssignCommand();
+                assignCommand.setShuttleNo(shuttleProtocol.getShuttleNo());//鍥涘悜绌挎杞﹀彿
+                assignCommand.setTaskNo(wrkMast.getWrkNo().shortValue());//浠诲姟鍙�
+                assignCommand.setTaskMode(ShuttleTaskModeType.PAK_IN.id.shortValue());//鍏ュ嚭搴撴ā寮�
+                assignCommand.setSourceLocNo(currentLocNo);//婧愬簱浣�(灏忚溅褰撳墠浣嶇疆)
+
+                //灏忚溅绉诲姩鍒版彁鍗囨満鍙o紝璁$畻璺緞
+                List<ShuttleCommand> commands = this.shuttleAssignCommand(shuttleProtocol.getLocNo(), liftSiteLocNo, NavigationMapType.NONE.id, assignCommand, shuttleThread);
+                if (commands == null) {
+                    return false;//鏈壘鍒拌矾寰�
+                }
+
+                //鑾峰彇褰撳墠灏忚溅鎵�鍦ㄦゼ灞傜殑绔欑偣淇℃伅
+                BasDevp basDevp = basDevpService.queryByLocNo(liftSiteLocNo);
+                Short endStartCode = Short.parseShort(basDevp.getQrCodeValue());//绔欑偣浜岀淮鐮�
+
+                //澧炲姞绉诲姩杩涙彁鍗囨満鍛戒护
+                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(endStartCode, liftProtocol.getBarcode(), 1600, ShuttleRunDirection.TOP.id, null, null, 500);
+                commands.add(moveCommand);
+
+                //鍒嗛厤鐩爣搴撲綅
+                shuttleProtocol.setLocNo(liftSiteLocNo);
+                //鐩爣搴撲綅
+                assignCommand.setLocNo(liftSiteLocNo);
+                assignCommand.setCommands(commands);
+                wrkMast.setWrkSts(5L);//灏忚溅杩佺Щ鐘舵��
+
+                if (wrkMastMapper.updateById(wrkMast) > 0) {
+                    //涓嬪彂浠诲姟
+                    MessageQueue.offer(SlaveType.Shuttle, assignCommand.getShuttleNo().intValue(), new Task(3, assignCommand));
                 }
             }
         }
+        return true;
+    }
+
+    /**
+     * 鍚屾ゼ灞傚簱浣嶇Щ杞�
+     * 濡傞渶涓绘柟娉曟墽琛宑ontinue锛岃杩斿洖false
+     * ps:杩斿洖鍊紅rue骞朵笉浠h〃璇ユ柟娉曟墽琛屾垚鍔燂紝杩斿洖鍊间粎鍋氭爣璁扮敤浜庝富鏂规硶鏄惁鎵цcontinue
+     */
+    private boolean locToLocExecuteStep3(WrkMast wrkMast) {
+        if (wrkMast.getShuttleNo() == null) {
+            return false;
+        }
+
+        ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, wrkMast.getShuttleNo());
+        ShuttleProtocol shuttleProtocol = shuttleThread.getShuttleProtocol();
+        if (!shuttleProtocol.isIdle(wrkMast.getWrkNo().shortValue())) {
+            return false;//灏忚溅澶勪簬涓嶇┖闂茬姸鎬�
+        }
+
+        LiftThread liftThread = (LiftThread) SlaveConnection.get(SlaveType.Lift, 1);
+        LiftProtocol liftProtocol = liftThread.getLiftProtocol();
+
+        DevpThread devpThread = null;
+        for (DevpSlave devp : slaveProperties.getDevp()){
+            // 鑾峰彇鍏ュ簱绔欎俊鎭�
+            devpThread = (DevpThread) SlaveConnection.get(SlaveType.Devp, devp.getId());
+        }
+
+        //鍒ゆ柇灏忚溅鏄惁鍦ㄥ伐浣滄。浠诲姟鐩爣妤煎眰
+        String currentLocNo = shuttleProtocol.getCurrentLocNo();//灏忚溅褰撳墠搴撲綅鍙�
+        int shuttleLev = Utils.getLev(currentLocNo);//灏忚溅鎵�鍦ㄦゼ灞�
+        if (shuttleLev != Utils.getLev(wrkMast.getLocNo())) {
+            return false;//涓嶅湪鍚屼竴妤煎眰
+        }
+
+        if (wrkMast.getWrkSts() == 1 || wrkMast.getWrkSts() == 8) {
+            //璋冨害灏忚溅鎵ц鍚屾ゼ灞傜Щ搴撲换鍔�
+
+            //鍒涘缓鍒嗛厤鍛戒护
+            ShuttleAssignCommand assignCommand = new ShuttleAssignCommand();
+            assignCommand.setShuttleNo(shuttleProtocol.getShuttleNo());//鍥涘悜绌挎杞﹀彿
+            assignCommand.setTaskNo(wrkMast.getWrkNo().shortValue());//浠诲姟鍙�
+            assignCommand.setTaskMode(ShuttleTaskModeType.PAK_IN.id.shortValue());//鍏ュ嚭搴撴ā寮�
+            assignCommand.setSourceLocNo(currentLocNo);//婧愬簱浣�(灏忚溅褰撳墠浣嶇疆)
+
+            List<ShuttleCommand> commands = new ArrayList<>();
+
+            if (wrkMast.getWrkSts() == 8) {//8.鎻愬崌鏈鸿縼绉诲皬杞﹀畬鎴愶紝闇�瑕佸皢灏忚溅绉诲嚭鎻愬崌鏈�
+                //鍒ゆ柇鎻愬崌鏈烘槸鍚︾┖闂�
+                if (!liftProtocol.isIdleNoTask()) {
+                    return false;//鎻愬崌鏈哄繖
+                }
+                //鍒ゆ柇鎻愬崌鏈轰换鍔″彿鍜屽綋鍓嶅伐浣滄。浠诲姟鍙锋槸鍚︿竴鑷�
+                if (liftProtocol.getTaskNo().intValue() != 0 && liftProtocol.getTaskNo().intValue() != wrkMast.getWrkNo()) {
+                    return false;
+                }
+
+                //鍒ゆ柇鎻愬崌鏈烘ゼ灞傛槸鍚﹀埌浣嶏紝鍒ゆ柇绔欑偣鏄惁缁欏嚭鎻愬崌鏈哄埌浣嶄俊鍙�
+                String locNo = wrkMast.getLocNo();
+                int lev = Utils.getLev(locNo);//鐩爣浜岀淮鐮佹墍鍦ㄦゼ灞�
+                int liftLev = liftProtocol.getLev().intValue();//鎻愬崌鏈烘墍鍦ㄦゼ灞�
+                if (liftLev != lev) {
+                    return false;//鎻愬崌鏈轰笉鍦ㄧ洰鏍囨ゼ灞傝烦杩�
+                }
+
+                Integer staNo = Utils.levToOutInStaNo(lev >= 2 ? lev + 1 : lev);
+                //鑾峰彇鐩爣绔欎俊鎭�
+                StaProtocol staProtocol1 = devpThread.getStation().get(staNo);
+                if (staProtocol1 == null) {
+                    return false;//绔欑偣淇℃伅涓嶅瓨鍦�
+                }
+                if (!staProtocol1.isLiftArrival()) {
+                    return false;//绔欑偣鎻愬崌鏈哄埌浣嶄俊鍙穎alse
+                }
+
+                BasDevp basDevp = basDevpService.selectById(staNo);
+                short startCode = liftProtocol.getBarcode();//鎻愬崌鏈哄唴閮ㄤ簩缁寸爜
+                Short distCode = Short.parseShort(basDevp.getQrCodeValue());//鎻愬崌鏈哄彛绔欑偣浜岀淮鐮�
+                Short runDirection = ShuttleRunDirection.BOTTOM.id;//杩愯鏂瑰悜
+                //鑾峰彇鍛戒护
+                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1600, runDirection, null, null, 500);
+                commands.add(0, moveCommand);//灏嗚鎸囦护娣诲姞鍒伴槦澶�
+
+                currentLocNo = basDevp.getLocNo();//浣跨敤杈撻�佺珯鐐瑰彛浣滀负璧风偣鍧愭爣
+            }
+
+            //鐩存帴璁$畻杞﹀埌婧愬簱浣嶅埌鐩爣搴撲綅璺緞
+            List<ShuttleCommand> commands1 = this.shuttleAssignCommand(currentLocNo, wrkMast.getSourceLocNo(), wrkMast.getLocNo(), assignCommand, shuttleThread);
+            if (commands1 == null) {
+                return false;//鎵句笉鍒拌矾寰勭瓑寰呬笅涓�娆�
+            }
+            commands.addAll(commands1);
+
+            //鍒嗛厤浠诲姟鍙�
+            shuttleProtocol.setTaskNo(wrkMast.getWrkNo().shortValue());
+            //鍒嗛厤婧愬簱浣�
+            shuttleProtocol.setSourceLocNo(wrkMast.getSourceLocNo());
+
+            assignCommand.setCommands(commands);
+            //鍒嗛厤鐩爣搴撲綅
+            shuttleProtocol.setLocNo(wrkMast.getLocNo());
+            //鐩爣搴撲綅
+            assignCommand.setLocNo(wrkMast.getLocNo());
+            wrkMast.setWrkSts(9L);//灏忚溅鍏ュ簱涓�
+            if (wrkMastMapper.updateById(wrkMast) > 0) {
+                //涓嬪彂浠诲姟
+                MessageQueue.offer(SlaveType.Shuttle, assignCommand.getShuttleNo().intValue(), new Task(3, assignCommand));
+            }
+        }
+
+        return true;
     }
 
     /**
@@ -2825,7 +2772,7 @@
                     Short basDevpQrCode = Short.parseShort(basDevp.getQrCodeValue());//绔欑偣浜岀淮鐮�
 
                     //澧炲姞绉诲姩杩涙彁鍗囨満鍛戒护
-                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(basDevpQrCode, liftProtocol.getBarcode(), 1400, ShuttleRunDirection.TOP.id, basDevpQrCode, 1400, 500);
+                    ShuttleCommand moveCommand = shuttleThread.getMoveCommand(basDevpQrCode, liftProtocol.getBarcode(), 1600, ShuttleRunDirection.TOP.id, basDevpQrCode, 1600, 500);
                     commands.add(moveCommand);
 
                     //鍒嗛厤鐩爣搴撲綅
@@ -2915,7 +2862,7 @@
                 Short distCode = Short.parseShort(basDevp.getQrCodeValue());//鎻愬崌鏈哄彛绔欑偣浜岀淮鐮�
                 Short runDirection = ShuttleRunDirection.BOTTOM.id;//杩愯鏂瑰悜
                 //鑾峰彇鍛戒护
-                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1400, runDirection, startCode, 1400, 500);
+                ShuttleCommand moveCommand = shuttleThread.getMoveCommand(startCode, distCode, 1600, runDirection, startCode, 1600, 500);
                 commands.add(0, moveCommand);//灏嗚鎸囦护娣诲姞鍒伴槦澶�
 
                 //杩涜鍏呯數涓�
@@ -2983,183 +2930,7 @@
 
     }
 
-    public List<String> crn2DemoLocs = new ArrayList<String>(); public String crn2LastLoc = "";
-    public synchronized void demo() {
-        if (Cools.isEmpty(crn2DemoLocs)) {
-            crn2DemoLocs = locMastService.getDemoNextLoc(2);
-        }
-        for (CrnSlave crn : slaveProperties.getCrn()) {
-            if (!crn.getDemo()) {
-                continue;
-            }
-            // 蹇呴』涓烘紨绀虹姸鎬�
-            CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
-            CrnProtocol crnProtocol = crnThread.getCrnProtocol();
-            if (crnProtocol == null) {
-                continue;
-            }
 
-            // 鍙湁褰撳爢鍨涙満绌洪棽 骞朵笖 鏃犱换鍔℃椂鎵嶇户缁墽琛�
-            if (crnProtocol.getStatusType() == CrnStatusType.IDLE && crnProtocol.getTaskNo() == 0 && crnProtocol.getModeType() == CrnModeType.AUTO) {
-
-                // filter
-                if (wrkChargeService.selectCount(new EntityWrapper<WrkCharge>()
-                        .eq("crn_no", crn.getId()).between("wrk_sts", 31, 36)) > 0) {
-                    continue;
-                }
-
-                SteThread steThread = queryIdleCar(crnProtocol);
-                if (Cools.isEmpty(steThread)) {
-                    News.warn("娌℃湁绌洪棽鐨勫皬杞﹁繘琛屾紨绀哄姛鑳�");
-                    continue;
-                }
-                int steNo = steThread.getSlave().getId();
-                SteProtocol steProtocol = steThread.getSteProtocol();
-                BasSte basSte = basSteService.selectById(steNo);
-                if (Cools.isEmpty(steProtocol, basSte)) { continue; }
-
-                // 鍙湁褰撶┛姊溅绌洪棽 骞朵笖 鏃犱换鍔℃椂鎵嶇户缁墽琛�
-                if (steProtocol.isIdle()) {
-
-                    String locNo = null;
-                    Iterator<String> iterator = crn2DemoLocs.iterator();
-                    while (iterator.hasNext()) {
-                        String next = iterator.next();
-                        if (!Cools.isEmpty(this.hasCar(next))) { continue; }
-                        String lastLoc = crn2LastLoc;
-                        if (!Cools.isEmpty(lastLoc)) {
-                            if (!lastLoc.substring(2, 7).equals(next.substring(2, 7))
-                                    || !Utils.getGroupRow(lastLoc, true).equals(Utils.getGroupRow(next, true))) {
-                                locNo = next;
-                                iterator.remove();
-                                break;
-                            } else {
-                                iterator.remove();
-                            }
-                        } else {
-                            locNo = next;
-                            iterator.remove();
-                            break;
-                        }
-
-                    }
-                    if (!Cools.isEmpty(locNo)) {
-                        crn2LastLoc = locNo;
-                    }
-
-                    News.info("{}鍙峰爢鍨涙満瀵箋}搴撲綅杩涜婕旂ず", crn.getId(), locNo);
-
-                    String sourceLocNo = Utils.getLocNo(steProtocol.getRow(), steProtocol.getBay(), steProtocol.getLev());
-
-                    WrkCharge wrkCharge = new WrkCharge();
-                    wrkCharge.setCrnNo(crn.getId());
-                    wrkCharge.setSteNo(steNo);
-                    wrkCharge.setWrkNo(commonService.getChargeWorkNo(5));
-                    wrkCharge.setWrkSts(31L);   // 31.鐢熸垚婕旂ずID
-                    wrkCharge.setIoPri((double) 10);
-                    wrkCharge.setSourceLocNo(sourceLocNo);
-                    wrkCharge.setLocNo(locNo);
-                    wrkCharge.setMemo("demo");
-                    if (!wrkChargeService.insert(wrkCharge)) {
-                        News.error("鐢熸垚婕旂ず浠诲姟澶辫触锛屽爢鍨涙満鍙凤細{}锛屽皬杞︼細{}锛屾簮搴撲綅锛歿}锛岀洰鏍囧簱浣嶏細{}", crn.getId(), steNo, sourceLocNo, locNo);
-                    }
-                }
-            }
-        }
-    }
-
-    /**
-     * 婕旂ず鍙栬揣
-     */
-    private void steMoveDemo(CrnSlave slave, CrnProtocol crnProtocol) {
-        // 鑾峰彇宸ヤ綔妗d俊鎭�
-        WrkCharge wrkCharge = wrkChargeService.selectOne(new EntityWrapper<WrkCharge>().eq("crn_no", slave.getId())
-                .in("wrk_sts", 31, 33, 35));
-        if (null == wrkCharge) {
-            return;
-        }
-        SteThread steThread = (SteThread) SlaveConnection.get(SlaveType.Ste, wrkCharge.getSteNo());
-        SteProtocol steProtocol = steThread.getSteProtocol();
-        if (null == steProtocol) { return; }
-        if (steProtocol.isIdle()) {
-            // 31.鐢熸垚婕旂ずID
-            if (wrkCharge.getWrkSts() == 31L) {
-                this.letCarBeReady(wrkCharge, steProtocol.getSteNo().intValue());
-                wrkCharge.setWrkSts(32L);
-                wrkCharge.setModiTime(new Date());
-                if (!wrkChargeService.updateById(wrkCharge)) {
-                    News.error("淇敼婕旂ず浠诲姟{}宸ヤ綔妗� 31.鐢熸垚婕旂ずID ==>> 32.灏忚溅璧拌 澶辫触!", wrkCharge.getWrkNo());
-                }
-            // 33.灏忚溅寰呮惉
-            } else if (wrkCharge.getWrkSts() == 33L) {
-                LocMast locMast = locMastService.selectById(wrkCharge.getLocNo());
-                // 鍫嗗灈鏈哄懡浠や笅鍙戝尯 --------------------------------------------------------------------------
-                CrnCommand crnCommand = new CrnCommand();
-                crnCommand.setCrnNo(crnProtocol.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
-                crnCommand.setTaskNo(wrkCharge.getWrkNo().shortValue()); // 宸ヤ綔鍙�
-                crnCommand.setAckFinish((short) 0);  // 浠诲姟瀹屾垚纭浣�
-                crnCommand.setTaskMode(CrnTaskModeType.STE_MOVE); // 浠诲姟妯″紡:  搴撲綅绉昏浆
-                crnCommand.setSourcePosX(Utils.getGroupRow(steProtocol.getRow().intValue(), true).shortValue());     // 婧愬簱浣嶆帓
-                crnCommand.setSourcePosY(steProtocol.getBay());     // 婧愬簱浣嶅垪
-                crnCommand.setSourcePosZ(steProtocol.getLev());     // 婧愬簱浣嶅眰
-                crnCommand.setDestinationPosX(Utils.getGroupRow(locMast.getLocNo(), true).shortValue());     // 鐩爣搴撲綅鎺�
-                crnCommand.setDestinationPosY(locMast.getBay1().shortValue());     // 鐩爣搴撲綅鍒�
-                crnCommand.setDestinationPosZ(locMast.getLev1().shortValue());     // 鐩爣搴撲綅灞�
-                if (!MessageQueue.offer(SlaveType.Crn, wrkCharge.getCrnNo(), new Task(2, crnCommand))) {
-                    News.error("鍫嗗灈鏈哄懡浠や笅鍙戝け璐ワ紝鍫嗗灈鏈哄彿={}锛屼换鍔℃暟鎹�={}", wrkCharge.getCrnNo(), JSON.toJSON(crnCommand));
-                } else {
-                    // 淇敼绌挎杞﹁繍琛屼腑鎺掑垪灞�
-                    steThread.modifyPos(Utils.getGroupRow(locMast.getLocNo(), true), locMast.getBay1(), locMast.getLev1());
-                    // 淇敼宸ヤ綔妗g姸鎬� 33.灏忚溅寰呮惉 => 34.鍚婅溅鎼繍
-                    Date now = new Date();
-                    wrkCharge.setWrkSts(34L);
-                    wrkCharge.setCrnStrTime(now);
-                    wrkCharge.setModiTime(now);
-                    if (!wrkChargeService.updateById(wrkCharge)) {
-                        News.error("淇敼婕旂ず浠诲姟{}宸ヤ綔妗� 33.灏忚溅寰呮惉 => 34.鍚婅溅鎼繍 澶辫触!", wrkCharge.getWrkNo());
-                    }
-                }
-                // 35.灏忚溅灏辩华
-            } else if (wrkCharge.getWrkSts() == 35L) {
-
-                int steNo = steProtocol.getSteNo().intValue();
-                if (!basSteService.updatePakMk(steNo, "Y")) {
-                    News.error("淇敼绌挎杞︿綔涓氱姸鎬� 澶辫触锛侊紒锛岀┛姊溅={}", steNo);
-                    return;
-                }
-
-                // 鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
-                SteCommand steCommand = new SteCommand();
-                steCommand.setSteNo(steNo); // 绌挎杞︾紪鍙�
-                steCommand.setTaskNo(wrkCharge.getWrkNo()); // 宸ヤ綔鍙�
-                SteTaskModeType originByLoc = SteTaskModeType.findOriginByLoc(steProtocol.getRow().intValue());
-                if (originByLoc.equals(SteTaskModeType.GO_ORIGIN)) {
-                    originByLoc = SteTaskModeType.BACK_ORIGIN;
-                } else if (originByLoc.equals(SteTaskModeType.BACK_ORIGIN)) {
-                    originByLoc = SteTaskModeType.GO_ORIGIN;
-                } else {
-                    return;
-                }
-                steCommand.setTaskMode(originByLoc);
-
-                steCommand.setRow(Utils.getGroupRow(steProtocol.getRow().intValue(), false).shortValue());
-                steCommand.setBay(steProtocol.getBay());
-                steCommand.setLev(steProtocol.getLev());
-
-                if (!MessageQueue.offer(SlaveType.Ste, steNo, new Task(2, steCommand))) {
-                    News.error("绌挎杞﹀懡浠や笅鍙戝け璐ワ紝绌挎杞﹀彿={}锛屼换鍔℃暟鎹�={}", steNo, JSON.toJSON(steCommand));
-                } else {
-                    // 淇敼宸ヤ綔妗g姸鎬� 35.灏忚溅灏辩华 => 36.灏忚溅璧拌
-                    wrkCharge.setWrkSts(36L);
-                    wrkCharge.setModiTime(new Date());
-                    if (!wrkChargeService.updateById(wrkCharge)) {
-                        News.error("淇敼婕旂ず浠诲姟{}宸ヤ綔妗� 35.灏忚溅灏辩华 => 36.灏忚溅璧拌 澶辫触!", wrkCharge.getWrkNo());
-                    }
-                }
-            }
-        }
-
-    }
     /**
      * 鍑哄叆搴撴ā寮忓垏鎹�
      */

--
Gitblit v1.9.1