From 4dfe6a8238e9036a10198f72ce811f5902f27bea Mon Sep 17 00:00:00 2001
From: lsh <lsh@163.com>
Date: 星期三, 22 十月 2025 16:52:44 +0800
Subject: [PATCH] *

---
 src/main/java/com/zy/asrs/controller/RgvController.java |  130 ++++++++++++++++++++++++++++++++++++++----
 1 files changed, 116 insertions(+), 14 deletions(-)

diff --git a/src/main/java/com/zy/asrs/controller/RgvController.java b/src/main/java/com/zy/asrs/controller/RgvController.java
index 1329076..62e85d8 100644
--- a/src/main/java/com/zy/asrs/controller/RgvController.java
+++ b/src/main/java/com/zy/asrs/controller/RgvController.java
@@ -10,10 +10,7 @@
 import com.zy.asrs.domain.vo.*;
 import com.zy.asrs.entity.*;
 import com.zy.asrs.mapper.BasRgvErrMapper;
-import com.zy.asrs.service.BasCircularShuttleService;
-import com.zy.asrs.service.BasDevpPositionService;
-import com.zy.asrs.service.BasRgvService;
-import com.zy.asrs.service.WrkMastService;
+import com.zy.asrs.service.*;
 import com.zy.asrs.service.impl.MainServiceImpl;
 import com.zy.asrs.utils.NumUtils;
 import com.zy.asrs.utils.Utils;
@@ -36,13 +33,11 @@
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.web.bind.annotation.PostMapping;
 import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
 import org.springframework.web.bind.annotation.RestController;
 
 import javax.rmi.CORBA.Util;
-import java.util.ArrayList;
-import java.util.HashMap;
-import java.util.List;
-import java.util.Map;
+import java.util.*;
 
 /**
  * RGV鎺ュ彛
@@ -60,7 +55,13 @@
     @Autowired
     private BasRgvErrMapper basRgvErrMapper;
     @Autowired
+    private BasRgvErrLogService basRgvErrLogService;
+    @Autowired
+    private BasRgvOptService basRgvOptService;
+    @Autowired
     private BasRgvService basRgvService;
+    @Autowired
+    private BasDevpService basDevpService;
     @Autowired
     private MainServiceImpl mainService;
     @Autowired
@@ -354,12 +355,14 @@
 //            double[] doubles = Utils.RingThroughXY2(perimeter, NumUtils.GetRandomIntInRange(183));
 //            double[] doubles = Utils.RingThroughXYRgv(perimeter, perimeter-rgvProtocol.RgvPos.doubleValue());
             double[] doubles = Utils.getRgvPosNew(perimeter, rgvProtocol.RgvPos.doubleValue());
-//            double[] doubles = Utils.RingThroughXY2(183.0, 100*i );
 
-            ringThroughParam.setValueX(doubles[0]-2.94);
-            ringThroughParam.setValueY(doubles[1]-2.94);
+            ringThroughParam.setValueX(doubles[0]);
+            ringThroughParam.setValueY(doubles[1]);
             ringThroughParam.setModeColor(rgvProtocol.modeType.color);
             ringThroughParam.setStatusColor(rgvProtocol.statusType.color);
+            if (rgvProtocol.getModeType() == RgvModeType.AUTO){
+                ringThroughParam.setAnimation(2);
+            }
             result.add(ringThroughParam);
         }
         return R.ok().add(result);
@@ -372,11 +375,42 @@
         List<RingThroughParam> result = new ArrayList<>();
         List<BasDevpPosition> basDevpPositions = basDevpPositionService.selectList(new EntityWrapper<>());
         for (BasDevpPosition basDevpPosition : basDevpPositions){
+            if (basDevpPosition.getDevRegion() == 0){
+                continue;
+            }
             RingThroughParam ringThroughParam = new RingThroughParam();
+
+            ringThroughParam.setModeColor("#FFFFFF");
+            ringThroughParam.setStatusColor("#FFFFFF");
+            try{
+                BasDevp basDevp = basDevpService.selectOne(new EntityWrapper<BasDevp>().eq("dev_no",basDevpPosition.getDevNo()));
+                if (basDevp.getAutoing().equals("Y")){
+                    if (basDevp.getLoading().equals("Y")){
+                        ringThroughParam.setModeColor("#ab1839");
+                        ringThroughParam.setStatusColor("#ab1839");
+                    }
+                    if (basDevp.getLoading().equals("N")){
+                        ringThroughParam.setModeColor("#27AE60");
+                        ringThroughParam.setStatusColor("#27AE60");
+                    }
+                } else {
+                    ringThroughParam.setModeColor("#C0392B");
+                    ringThroughParam.setStatusColor("#C0392B");
+                }
+
+            } catch (Exception e){
+                System.out.println(e.getMessage());
+                ringThroughParam.setModeColor("#000000");
+                ringThroughParam.setStatusColor("#000000");
+
+            }
             ringThroughParam.setIndex(basDevpPosition.getDevNo());
-            double[] doubles = Utils.RingThroughXYSta(perimeter, perimeter-basDevpPosition.getPlcPosition());
-            ringThroughParam.setValueX(doubles[0]>50? doubles[0]+6:doubles[0]-1);
-            ringThroughParam.setValueY(doubles[1]>50? doubles[1]+6:doubles[1]-1);
+//            double[] doubles = Utils.RingThroughXYSta(perimeter, perimeter-basDevpPosition.getPlcPosition());
+//            ringThroughParam.setValueX(doubles[0]>50? doubles[0]+6:doubles[0]-1);
+//            ringThroughParam.setValueY(doubles[1]>50? doubles[1]+6:doubles[1]-1);
+            double[] doubles = Utils.getRgvPosNew(basDevpPosition.getDevNo(),perimeter, basDevpPosition.getPlcPosition());
+            ringThroughParam.setValueX(doubles[0]);
+            ringThroughParam.setValueY(doubles[1]);
             result.add(ringThroughParam);
         }
         return R.ok().add(result);
@@ -448,6 +482,19 @@
         return R.ok().add(result);
     }
 
+    @PostMapping("/ring/through/task/wrk/mast/position/data/v1")
+//    @ManagerAuth(memo = "浣滀笟淇℃伅")
+    public R ringThroughTaskWrkMastV1(){
+        List<BasRgvOpt> result = new ArrayList<>();
+        for (int i = 1 ; i<11; i ++){
+            BasRgvOpt basRgvOpt = basRgvOptService.selectOne(new EntityWrapper<BasRgvOpt>().eq("rgv_no", i).orderBy("id", false));
+            if (basRgvOpt!=null){
+                result.add(basRgvOpt);
+            }
+        }
+        return R.ok().add(result);
+    }
+
     @PostMapping("/task/rgv/circular/shuttle/mast/position/data")
 //    @ManagerAuth(memo = "浣滀笟淇℃伅")
     public R rgvCircularShuttle(){
@@ -464,6 +511,21 @@
                         if (rgvCircularShuttleParam.getStatus()==0){
                             rgvCircularShuttleParam.setStatus$(rgvProtocol.statusType.desc);
                         }
+                        if (rgvProtocol.getAlarmList().isEmpty()){
+                            rgvCircularShuttleParam.setError(0);
+                            rgvCircularShuttleParam.setError$("-");
+                        } else {
+                            StringBuilder alarmList = new StringBuilder();
+                            for (Integer alarm : rgvProtocol.getAlarmList()){
+                                BasRgvErr rgvErr = basRgvErrMapper.selectById(alarm);
+                                alarmList.append((rgvErr==null || rgvErr.getErrName()==null)? "鏈煡寮傚父:"+alarm:rgvErr.getErrName());
+                                if (alarm.equals(rgvProtocol.getAlarmList().get(rgvProtocol.getAlarmList().size() - 1))){
+                                    break;
+                                }
+                                alarmList.append("---");
+                            }
+                            rgvCircularShuttleParam.setError$(alarmList.toString());
+                        }
                     }
                 }
             }
@@ -472,4 +534,44 @@
         return R.ok().add(result);
     }
 
+    @PostMapping("/task/rgv/circular/shuttle/mast/position/data/v1")
+//    @ManagerAuth(memo = "浣滀笟淇℃伅")
+    public R rgvCircularShuttleV1(){
+        List<BasRgvErrLog> result = new ArrayList<>();
+        for (int i = 1 ; i<11; i ++){
+            BasRgvErrLog basRgvErrLog = basRgvErrLogService.selectOne(new EntityWrapper<BasRgvErrLog>().eq("rgv_no", i).orderBy("id", false));
+            if (basRgvErrLog!=null){
+                result.add(basRgvErrLog);
+            }
+        }
+        return R.ok().add(result);
+    }
+
+
+    @PostMapping("/disable/rgv/status")
+//    @ManagerAuth(memo = "淇敼RGV鐘舵��")
+    public R rgvDisableStatus(@RequestParam Integer rgvNo,
+                              @RequestParam Integer status){
+        log.info("/disable/rgv/status===銆嬩慨鏀筊GV鐘舵�侊紒锛侊紒rgvNo:{},status:{},data:{}",rgvNo,status,new Date());
+        BasCircularShuttle basCircularShuttle = basCircularShuttleService.selectOne(new EntityWrapper<BasCircularShuttle>().eq("rgv_no", rgvNo));
+        if (basCircularShuttle == null){
+            return R.error().add("鏈壘鍒版RGV锛屽紓甯革紒锛侊紒");
+        }
+        basCircularShuttle.setStatus(status);
+        basCircularShuttleService.updateById(basCircularShuttle);
+        return R.ok();
+    }
+
+    @PostMapping("/disable/task/delete")
+//    @ManagerAuth(memo = "鍒犻櫎浠诲姟")
+    public R taskDisabledelete(@RequestParam Long wrkNo){
+        log.info("/disable/task/delete===銆嬪垹闄や换鍔★紒锛侊紒wrkNo:{},data:{}",wrkNo,new Date());
+        WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("wrk_no", wrkNo));
+        if (Cools.isEmpty(wrkMast)){
+            return R.error().add("鏈壘鍒版浠诲姟锛屽紓甯革紒锛侊紒");
+        }
+        wrkMastService.deleteById(wrkMast);
+        return R.ok();
+    }
+
 }
\ No newline at end of file

--
Gitblit v1.9.1