From de6a34c248036d65a3d6797c83e051acdeb78bf7 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 21 十月 2024 15:18:33 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/map/constants.js                                                       |    2 ++
 zy-acs-manager/src/main/java/com/zy/acs/manager/core/domain/MapWsAgvVo.java            |    2 ++
 zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MapDataWsScheduler.java |    6 ++++++
 zy-acs-flow/src/map/tool.js                                                            |   49 ++++++++++++++++++++++++++++++++++++++++++++-----
 4 files changed, 54 insertions(+), 5 deletions(-)

diff --git a/zy-acs-flow/src/map/constants.js b/zy-acs-flow/src/map/constants.js
index a88723d..192090a 100644
--- a/zy-acs-flow/src/map/constants.js
+++ b/zy-acs-flow/src/map/constants.js
@@ -26,6 +26,8 @@
 
     AGV: 3,
     POINT: 2,
+
+    DYNAMIC_ROUTE: 2,
 })
 
 export const DEVICE_SPRITE_TINT = Object.freeze({
diff --git a/zy-acs-flow/src/map/tool.js b/zy-acs-flow/src/map/tool.js
index c84c2ca..ade4711 100644
--- a/zy-acs-flow/src/map/tool.js
+++ b/zy-acs-flow/src/map/tool.js
@@ -500,7 +500,7 @@
             const pointRoute = new PointRoute(POINT_ROUTE_DIRECTION[route.direction]);
             pointRoute.setPoint(startPoint, endPoint);
             pointRoute.clear();
-            pointRoute.lineStyle(8, themeMode === 'light' ? '#2d3436' : '#dcdde1');
+            pointRoute.lineStyle(Math.max(7, 1.5 * (1 / mapContainer.scale.x)), themeMode === 'light' ? '#ced6e0' : '#535c68');
             pointRoute.moveTo(startPoint.position.x, startPoint.position.y);
             pointRoute.lineTo(endPoint.position.x, endPoint.position.y);
             pointRoute.alpha = 1;
@@ -621,14 +621,16 @@
 export const generateDynamicGraphic = (curZone, data, setCurSprite) => {
     // console.log("ws", curZone, data);
 
-    for (const agv of data.agvVos) {
-        showAgvSprite(curZone, agv, setCurSprite)
+    for (const agvVo of data.agvVos) {
+        // console.log(agvVo);
+        showAgvSprite(curZone, agvVo, setCurSprite);
+        drawerAgvPath(curZone, agvVo);
     }
 
 }
 
-const showAgvSprite = (curZone, agv, setCurSprite) => {
-    const { agvNo, code, direction, backpack, battery, ...rest } = agv;
+const showAgvSprite = (curZone, agvVo, setCurSprite) => {
+    const { agvNo, code, direction, backpack, dynamicRoute, battery, ...rest } = agvVo;
     if (!code) { return }
     const codeSprite = querySprite(DEVICE_TYPE.POINT, code);
     if (!codeSprite) { return }
@@ -645,4 +647,41 @@
         beInsight(agvSprite, setCurSprite);
         // agv no on sprite
     }
+}
+
+const drawerAgvPath = (curZone, agvVo) => {
+    if (!mapContainer) {
+        return;
+    }
+    const { agvNo, code: curCode, dynamicRoute } = agvVo;
+    if (dynamicRoute?.length <= 1) {
+        return;
+    }
+
+    const agvPathName = 'agvPath-' + agvNo;
+    let agvPath = mapContainer.getChildByName(agvPathName);
+    if (agvPath) {
+        mapContainer.removeChild(agvPath);
+    }
+    agvPath = new PIXI.Graphics();
+    agvPath.name = agvPathName;
+    agvPath.lineStyle(Math.max(20, 4 * (1 / mapContainer.scale.x)), 0x2f68ac, 0.8);
+    agvPath.zIndex = DEVICE_Z_INDEX.DYNAMIC_ROUTE;
+    agvPath.blendMode = PIXI.BLEND_MODES.NORMAL;
+
+    let firstNode = true;
+    for (let i = Math.max(0, dynamicRoute.indexOf(curCode)); i < dynamicRoute.length; i++) {
+        const node = dynamicRoute[i];
+        const codeSprite = querySprite(DEVICE_TYPE.POINT, node);
+        if (!codeSprite) { continue };
+        const { x, y } = codeSprite.position;
+        if (firstNode) {
+            agvPath.moveTo(x, y);
+            firstNode = false;
+        } else {
+            agvPath.lineTo(x, y);
+        }
+    }
+
+    mapContainer.addChild(agvPath);
 }
\ No newline at end of file
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/domain/MapWsAgvVo.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/domain/MapWsAgvVo.java
index c564eb3..182f1f3 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/domain/MapWsAgvVo.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/domain/MapWsAgvVo.java
@@ -19,6 +19,8 @@
 
     private List<BackpackDto> backpack = new ArrayList<>();
 
+    private List<String> dynamicRoute = new ArrayList<>();
+
     private Integer battery;
 
 //    public int getBackpackLoadedCount() {
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MapDataWsScheduler.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MapDataWsScheduler.java
index 599a81d..ab38279 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MapDataWsScheduler.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/scheduler/MapDataWsScheduler.java
@@ -5,6 +5,7 @@
 import com.zy.acs.manager.core.domain.BackpackDto;
 import com.zy.acs.manager.core.domain.MapWsAgvVo;
 import com.zy.acs.manager.core.domain.MapWsVo;
+import com.zy.acs.manager.core.service.astart.MapDataDispatcher;
 import com.zy.acs.manager.manager.entity.Agv;
 import com.zy.acs.manager.manager.entity.AgvDetail;
 import com.zy.acs.manager.manager.entity.Code;
@@ -31,6 +32,8 @@
     private AgvDetailService agvDetailService;
     @Autowired
     private CodeService codeService;
+    @Autowired
+    private MapDataDispatcher mapDataDispatcher;
 
     @Scheduled(cron = "0/1 * * * * ? ")
     public void broadcast() {
@@ -58,6 +61,9 @@
             vo.setDirection(agvDetail.getAgvAngle());
             vo.setBackpack(GsonUtils.fromJsonToList(agvDetail.getBackpack(), BackpackDto.class));
             vo.setBattery(agvDetail.getSoc());
+
+            vo.setDynamicRoute(mapDataDispatcher.queryCodeListFromDynamicNode(null, agv.getUuid()));
+
             agvVos.add(vo);
         }
 

--
Gitblit v1.9.1