From 0f69561e397093b5165c4aac58530721d5c62178 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期一, 25 十一月 2024 11:03:16 +0800 Subject: [PATCH] #led --- zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapRealTimeDataScheduler.java | 50 +++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 49 insertions(+), 1 deletions(-) diff --git a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapRealTimeDataScheduler.java b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapRealTimeDataScheduler.java index 925be94..5b5eff6 100644 --- a/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapRealTimeDataScheduler.java +++ b/zy-asrs-wcs/src/main/java/com/zy/asrs/wcs/core/map/websocket/MapRealTimeDataScheduler.java @@ -1,13 +1,20 @@ package com.zy.asrs.wcs.core.map.websocket; import com.alibaba.fastjson.JSON; +import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.zy.asrs.framework.common.Cools; +import com.zy.asrs.wcs.core.domain.dto.MapLockPathDto; +import com.zy.asrs.wcs.core.entity.BasConveyorSta; import com.zy.asrs.wcs.core.entity.BasShuttle; import com.zy.asrs.wcs.core.map.entity.MapWsShuttleVo; import com.zy.asrs.wcs.core.map.entity.MapWsVo; +import com.zy.asrs.wcs.core.model.NavigateNode; import com.zy.asrs.wcs.core.model.enums.DeviceCtgType; +import com.zy.asrs.wcs.core.service.BasConveyorStaService; import com.zy.asrs.wcs.core.service.BasShuttleService; +import com.zy.asrs.wcs.core.utils.NavigateMapUtils; +import com.zy.asrs.wcs.core.utils.Utils; import com.zy.asrs.wcs.rcs.cache.SlaveConnection; import com.zy.asrs.wcs.rcs.entity.Device; import com.zy.asrs.wcs.rcs.model.enums.SlaveType; @@ -15,6 +22,8 @@ import com.zy.asrs.wcs.rcs.service.DeviceService; import com.zy.asrs.wcs.rcs.service.DeviceTypeService; import com.zy.asrs.wcs.rcs.thread.ShuttleThread; +import com.zy.asrs.wcs.system.entity.Dict; +import com.zy.asrs.wcs.system.service.DictService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -22,6 +31,7 @@ import java.util.ArrayList; import java.util.List; import java.util.function.Consumer; +import java.util.stream.Collectors; /** * Created by vincent on 4/11/2024 @@ -35,12 +45,20 @@ private DeviceService deviceService; @Autowired private BasShuttleService basShuttleService; + @Autowired + private DictService dictService; + @Autowired + private NavigateMapUtils navigateMapUtils; + @Autowired + private BasConveyorStaService basConveyorStaService; @Scheduled(cron = "0/1 * * * * ? ") public void sync() { MapWsVo wsVo = new MapWsVo(); // shuttle wsVo.setShuttleVos(syncShuttle()); + wsVo.setLockPath(getMapLocPath()); + wsVo.setConveyorSta(getMapConveyorSta()); MapWebSocket.broadcast(JSON.toJSONString(wsVo)); } @@ -61,7 +79,6 @@ if (null != basShuttle && !Cools.isEmpty(basShuttle.getProtocol())) { ShuttleProtocol protocol = JSON.parseObject(basShuttle.getProtocol(), ShuttleProtocol.class); shuttleVo.setCurLocNo(protocol.getCurrentLocNo()); - } } }; @@ -78,9 +95,40 @@ } shuttleVo.setCurLocNo(protocol.getCurrentLocNo()); + + List<NavigateNode> moveAdvancePath = thread.getMoveAdvancePath(); + if (!Cools.isEmpty(moveAdvancePath)) { + shuttleVo.setTravelPath(moveAdvancePath.stream() + .map(path -> Utils.getLocNo(path.getX(), path.getY(), path.getZ())) + .collect(Collectors.toList())); + } } return shuttleVos; } + private List<MapLockPathDto> getMapLocPath() { + List<MapLockPathDto> list = new ArrayList<>(); + Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>() + .eq(Dict::getFlag, "floor-list") + .eq(Dict::getStatus, 1)); + if (dict != null) { + for (Object o : JSON.parseArray(dict.getValue())) { + JSONObject jsonObject = JSON.parseObject(o.toString()); + Integer lev = jsonObject.getInteger("value"); + List<NavigateNode> path = navigateMapUtils.getLockPath(lev); + + MapLockPathDto lockPathDto = new MapLockPathDto(); + lockPathDto.setPath(path); + lockPathDto.setLev(lev); + list.add(lockPathDto); + } + } + return list; + } + + private List<BasConveyorSta> getMapConveyorSta() { + return basConveyorStaService.list(); + } + } -- Gitblit v1.9.1