From 96ffc9779885b70bbd886954fc756465f833374d Mon Sep 17 00:00:00 2001
From: L <L@132>
Date: 星期四, 17 七月 2025 16:46:55 +0800
Subject: [PATCH] *

---
 src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java |  139 +++++++++++++++++++++++++++++++++++++---------
 1 files changed, 112 insertions(+), 27 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 af4e0d1..1ceeefd 100644
--- a/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
+++ b/src/main/java/com/zy/asrs/service/impl/MainServiceImpl.java
@@ -93,9 +93,9 @@
     @Autowired
     private WrkMastStaMapper wrkMastStaMapper;
     @Autowired
-    private BasRgvMapMapper basRgvMapMapper;
-    @Autowired
     private RgvOneSignMapper rgvOneSignMapper;
+    @Autowired
+    private BasRgvMapService basRgvMapService;
 
     @Value("${wms.url}")
     private String wmsUrl;
@@ -3552,7 +3552,13 @@
                             if (!rgvComplete){
                                 log.error("灏忚溅澶嶄綅澶辫触锛屽皬杞﹀彿{}锛�",rgvProtocol.getRgvNo());
                             }
-                            BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                            RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                            int rgvSignTwoType = 0;
+                            if (!Cools.isEmpty(rgvSignTwo)){
+                                rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                            }
+                            BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                             basRgvMap.setNowRoute(rgvProtocol.getRgvPosI());
                             rgvMapUpdate(basRgvMap,basRgvMap.getStartRoute(),basRgvMap.getStartRoute());
                             break;
@@ -3630,7 +3636,13 @@
                         }
                         wrkMastSta.setWrkSts(3);
                         wrkMastStaMapper.updateById(wrkMastSta);
-                        BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                        RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                        int rgvSignTwoType = 0;
+                        if (!Cools.isEmpty(rgvSignTwo)){
+                            rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                        }
+                        BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                         basRgvMap.setNowRoute(rgvProtocol.getRgvPosI());
                         rgvMapUpdate(basRgvMap,basRgvMap.getStartRoute(),basRgvMap.getStartRoute());
                     }else if (rgvProtocol.getTaskNo2()!=0 && (rgvProtocol.getStatusType2()==RgvStatusType.WAITING || rgvProtocol.getStatusType2()==RgvStatusType.FETCHWAITING)){
@@ -3639,7 +3651,13 @@
                             if (!rgvComplete){
                                 log.error("灏忚溅澶嶄綅澶辫触锛屽皬杞﹀彿{}锛�",rgvProtocol.getRgvNo());
                             }
-                            BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                            RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                            int rgvSignTwoType = 0;
+                            if (!Cools.isEmpty(rgvSignTwo)){
+                                rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                            }
+                            BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                             basRgvMap.setNowRoute(rgvProtocol.getRgvPosI());
                             rgvMapUpdate(basRgvMap,basRgvMap.getStartRoute(),basRgvMap.getStartRoute());
                             break;
@@ -3688,7 +3706,13 @@
                         }
                         wrkMastSta.setWrkSts(3);
                         wrkMastStaMapper.updateById(wrkMastSta);
-                        BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                        RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                        int rgvSignTwoType = 0;
+                        if (!Cools.isEmpty(rgvSignTwo)){
+                            rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                        }
+                        BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                         basRgvMap.setNowRoute(rgvProtocol.getRgvPosI());
                         rgvMapUpdate(basRgvMap,basRgvMap.getStartRoute(),basRgvMap.getStartRoute());
                     }else {
@@ -3840,7 +3864,13 @@
                         && rgvProtocol.getLoaded1()==0
                         && rgvProtocol.getTaskNo1()==0 && rgvProtocol.getTaskNo2()==0
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(basRgv.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(basRgv.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -3955,7 +3985,13 @@
                     && rgvProtocol.getLoaded1()==0
                     && rgvProtocol.getTaskNo1()==0 && rgvProtocol.getTaskNo2()==0
             ) {
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(basRgv.getRgvNo());
+
+                RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                int rgvSignTwoType = 0;
+                if (!Cools.isEmpty(rgvSignTwo)){
+                    rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                }
+                BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(basRgv.getRgvNo(),rgvSignTwoType);
                 if (basRgvMap == null) {
                     log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                     return false;
@@ -4037,7 +4073,13 @@
                         && rgvProtocol.getLoaded1()==1
                         && rgvProtocol.getTaskNo1()!=0 && rgvProtocol.getTaskNo2()==0
             ) {// 鍙湁褰揜GV绌洪棽銆佽嚜鍔�,宸ヤ綅涓�鏈夌墿  鏈夊伐浣滃彿//rgv鍙敤
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(basRgv.getRgvNo());
+
+                RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                int rgvSignTwoType = 0;
+                if (!Cools.isEmpty(rgvSignTwo)){
+                    rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                }
+                BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(basRgv.getRgvNo(),rgvSignTwoType);
                 if (basRgvMap == null) {
                     log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                     return false;
@@ -4124,7 +4166,13 @@
                         && rgvProtocol.getTaskNo2()==0
                         && (rgvProtocol.getLoaded2()==3  || rgvProtocol.getLoaded2()==1 || rgvProtocol.getLoaded2()==4)////0 鏃犵墿锛�1 涓�灞傛棤鐗╀簩灞傛湁鐗� 锛堝彧鑳芥媶鍙狅級 锛�2涓�灞傛湁鐗╀簩灞傛棤鐗�() 锛�3  1銆�2灞傞兘鏈夌墿  4锛氾紙锛夊彧鍏佽鎷嗙洏
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(basRgv.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -4232,7 +4280,13 @@
                     && rgvProtocol.getLoaded1()==1
                     && rgvProtocol.getTaskNo1()!=0 && rgvProtocol.getTaskNo2()==0
             ) {
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                int rgvSignTwoType = 0;
+                if (!Cools.isEmpty(rgvSignTwo)){
+                    rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                }
+                BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                 if (basRgvMap == null) {
                     log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                     return false;
@@ -4345,7 +4399,13 @@
                         && rgvProtocol.getTaskNo2()==0
                         &&  (rgvProtocol.getLoaded2()==2  || rgvProtocol.getLoaded2()==3 ) ////0 鏃犵墿锛�1 涓�灞傛棤鐗╀簩灞傛湁鐗�  锛�2涓�灞傛湁鐗╀簩灞傛棤鐗� 锛堝彧鑳芥弧鏀撅級锛�3  1銆�2灞傞兘鏈夌墿  4锛氾紙锛夊彧鍏佽鎷嗙洏
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -4453,7 +4513,13 @@
                         && rgvProtocol.getTaskNo2()==0
                         &&  (rgvProtocol.getLoaded2()==0  || rgvProtocol.getLoaded2()==1 ) //鐜板満淇敼锛氬彔鐩樻満锛�////0 鏃犵墿锛�1 涓�灞傛棤鐗╀簩灞傛湁鐗╋紙鍙兘鎷嗗彔锛�   锛�2涓�灞傛湁鐗╀簩灞傛棤鐗� 锛堝彧鑳芥弧鏀撅級锛�3  1銆�2灞傞兘鏈夌墿  4锛氾紙锛夊彧鍏佽鎷嗙洏
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -4549,7 +4615,13 @@
                     && rgvProtocol.getLoaded1() == 0
                     && rgvProtocol.getTaskNo1()==0 && rgvProtocol.getTaskNo2()==0
             ) {
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                int rgvSignTwoType = 0;
+                if (!Cools.isEmpty(rgvSignTwo)){
+                    rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                }
+                BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                 if (basRgvMap == null) {
                     log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                     return false;
@@ -4638,7 +4710,13 @@
                         && rgvProtocol.getTaskNo2()==0
                         &&  rgvProtocol.getLoaded2()==0  //鐜板満淇敼锛氬彔鐩樻満锛�////0 鏃犵墿锛�1 涓�灞傛棤鐗╀簩灞傛湁鐗╋紙鍙兘鎷嗗彔锛�   锛�2涓�灞傛湁鐗╀簩灞傛棤鐗� 锛堝彧鑳芥弧鏀撅級锛�3  1銆�2灞傞兘鏈夌墿  4锛氾紙锛夊彧鍏佽鎷嗙洏
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -4732,7 +4810,13 @@
                         || (rgvProtocol.getTaskNo1()>0 && rgvProtocol.getLoaded1()==1))
                         && rgvProtocol.getTaskNo2()==0
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvProtocol.getRgvNo());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvProtocol.getRgvNo(),rgvSignTwoType);
                     if (basRgvMap == null) {
                         log.error("{}鍙稲GV灏氭湭鍦ㄦ暟鎹簱鍦板浘涓繘琛岀淮鎶わ紒", rgvProtocol.getRgvNo());
                         return false;
@@ -4925,7 +5009,13 @@
                         || (rgvProtocol.getTaskNo1()>0 && rgvProtocol.getLoaded1()==1))
                         && rgvProtocol.getTaskNo2()==0
                 ) {
-                    BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvSlave.getId());
+
+                    RgvOneSign rgvSignTwo = rgvOneSignMapper.selectOneSign("rgvTwo");
+                    int rgvSignTwoType = 0;
+                    if (!Cools.isEmpty(rgvSignTwo)){
+                        rgvSignTwoType = rgvSignTwo.getRgvOneSign();
+                    }
+                    BasRgvMap basRgvMap = basRgvMapService.selectByIdSignTwo(rgvSlave.getId(),rgvSignTwoType);
                     basRgvMap.setNowRoute(rgvProtocol.getRgvPosI());
                     rgvMapUpdate(basRgvMap,basRgvMap.getStartRoute(),basRgvMap.getStartRoute());
                 }
@@ -4945,7 +5035,6 @@
         }
         if (rgvId==1){
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -4968,7 +5057,6 @@
             }
         }else {
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -5000,7 +5088,6 @@
         }
         if (rgvId==2){
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -5027,7 +5114,6 @@
             }
         }else {
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -5064,7 +5150,6 @@
         }
         if (rgvId==1){
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -5087,7 +5172,6 @@
             }
         }else {
             try{
-                BasRgvMap basRgvMap = basRgvMapMapper.selectById(rgvId);
                 //  鍛戒护涓嬪彂鍖� --------------------------------------------------------------------------
                 RgvCommand rgvCommand = new RgvCommand();
                 rgvCommand.setRgvNo(rgvId); // RGV缂栧彿
@@ -5363,7 +5447,7 @@
         if (rgvOpen){
             return true;
         }
-        if (basRgvMapCurrent.getRgvNo()>20){
+        if (basRgvMapCurrent.getRgvNo()>2){
             return true;
         }
 //        List<Integer> integers = RouteUtils.RouteMapCurrentFar(basRgvMapCurrent.getNowRoute(),staStart,staEnd, basRgvMapCurrent.getLockStartRoute());
@@ -5373,16 +5457,17 @@
 //            Integer farCurrentStaNo = RouteUtils.RouteIndexFarMas(staEnd, staStart, staEnd, basRgvMapCurrent.getLockStartRoute());//鑾峰彇鏈�杩滅珯鐐�
             Integer fallMerge = RouteUtils.RouteIndexFarMas(basRgvMapCurrent.getRgvNo(), farCurrentStaNo); //鑾峰彇鍚堝苟骞叉秹椤�
             basRgvMapCurrent.setLockEndRoute(fallMerge);
-            basRgvMapMapper.updateById(basRgvMapCurrent);
+
+            basRgvMapService.updateById(basRgvMapCurrent);
 
             //鏇存柊鍙︿竴鍙板皬杞﹀湴鍥�
             Integer rgvNoOther = basRgvMapCurrent.getRgvNoOther();
-            BasRgvMap basRgvMapOther = basRgvMapMapper.selectById(rgvNoOther);
+            BasRgvMap basRgvMapOther = basRgvMapService.selectById(rgvNoOther);
             List<Integer> integers = RouteUtils.RouteMapCurrentFar(fallMerge, basRgvMapCurrent.getLockStartRoute());
             Integer lockEndRoute = RouteUtils.RouteMapOtherFarStnNo(integers, basRgvMapCurrent.getLockStartRoute());//鍙︿竴鍙板皬杞﹀彲娲诲姩鏈�杩滀綅缃�
             Integer lockEndRouteL = RouteUtils.RouteIndexFarMasL(rgvNoOther, lockEndRoute);//鍙︿竴鍙板皬杞﹀彲娲诲姩鏈�杩滀綅缃�
             basRgvMapOther.setEndRoute(lockEndRouteL);
-            basRgvMapMapper.updateById(basRgvMapOther);
+            basRgvMapService.updateById(basRgvMapOther);
             return true;
         }catch (Exception e){
             log.error("灏忚溅鍦板浘鏇存柊鍑洪敊锛�");

--
Gitblit v1.9.1