From 8e492faebda1640adfc30a780fc95b9ecd019c6d Mon Sep 17 00:00:00 2001 From: vincentlu <t1341870251@gmail.com> Date: 星期一, 13 一月 2025 10:34:39 +0800 Subject: [PATCH] # --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MapService.java | 36 ++++++++++++++++++++++++++++++------ 1 files changed, 30 insertions(+), 6 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MapService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MapService.java index 1e0ac79..d6c2b61 100644 --- a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MapService.java +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/MapService.java @@ -1,6 +1,5 @@ package com.zy.acs.manager.core.service; -import com.alibaba.fastjson.JSONObject; import com.zy.acs.common.enums.AgvDirectionType; import com.zy.acs.framework.common.Cools; import com.zy.acs.manager.common.utils.MapDataUtils; @@ -118,14 +117,14 @@ return floydNavigateService.calculatePath(startIdx, endIdx).stream().map(path -> { Long codeId = floydNavigateService.getCodeId(path); - Code code = codeService.getById(codeId); + Code code = codeService.getCacheById(codeId); return code.getData(); }).collect(Collectors.toList()); } // 瑙掑害璁$畻 - public Double calculateDirection(Code startCode, Code endCode) { + public Double calculateDirection(Code startCode, Code endCode, int angleOffsetVal) { Double x0 = startCode.getX(); Double y0 = startCode.getY(); @@ -135,7 +134,6 @@ double deltaX = x1 - x0; double deltaY = y1 - y0; double angle = -Math.atan2(deltaX, deltaY); - int angleOffsetVal = configService.getVal("mapAngleOffsetVal", Integer.class); angle = Math.toDegrees(angle) + angleOffsetVal; angle = (angle + 360) % 360; // 灏嗚搴﹁浆鎹负姝e�� @@ -143,8 +141,7 @@ } // 鍧愭爣璐ф灦闃堝�� todo:luxiaotao - public AgvDirectionType calculateAgvWorkDirection(JSONObject storeDirection, Loc loc, Code code) { - storeDirection.getString("key"); + public AgvDirectionType calculateAgvWorkDirection(Loc loc, Code code) { Integer compDirect = loc.getCompDirect(); AgvDirectionType agvDirectionType = null; if (compDirect == 0) { @@ -368,6 +365,33 @@ return turnMatrixNode == TurnNodeType.TURN.val; } + /** + * That vehicle is walking if the dynamic node count > 1 + */ + @SuppressWarnings("all") + public boolean isWalkingByVehicle(Integer lev, String vehicle) { + if (Cools.isEmpty(vehicle)) { + return false; + } + + lev = Optional.ofNullable(lev).orElse(MapDataDispatcher.MAP_DEFAULT_LEV); + DynamicNode[][] dynamicMatrix = mapDataDispatcher.getDynamicMatrix(lev); + + int count = 0; + for (int i = 0; i < dynamicMatrix.length; i++) { + for (int j = 0; j < dynamicMatrix[i].length; j++) { + if (vehicle.equals(dynamicMatrix[i][j].getVehicle())) { + count++; + if (count > 1) { + return true; + } + } + } + } + + return false; + } + public List<String> queryCodeListFromDynamicNode(Integer lev, String nodeType) { if (Cools.isEmpty(nodeType)) { return new ArrayList<>(); -- Gitblit v1.9.1