From 2d2afe482ec78ba72e945e467fa32ed9527a75dc Mon Sep 17 00:00:00 2001 From: zhang <zc857179121@qq.com> Date: 星期四, 03 七月 2025 10:33:39 +0800 Subject: [PATCH] 队列拆分 --- zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataNoCodeService.java | 143 +++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 143 insertions(+), 0 deletions(-) diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataNoCodeService.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataNoCodeService.java new file mode 100644 index 0000000..9323003 --- /dev/null +++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/core/service/AgvDataNoCodeService.java @@ -0,0 +1,143 @@ +package com.zy.acs.manager.core.service; + +import com.alibaba.fastjson.JSON; +import com.zy.acs.common.domain.AgvProtocol; +import com.zy.acs.common.domain.protocol.AGV_13_UP; +import com.zy.acs.common.domain.protocol.IMessageBody; +import com.zy.acs.common.enums.AgvStatusType; +import com.zy.acs.common.utils.GsonUtils; +import com.zy.acs.common.utils.RedisSupport; +import com.zy.acs.manager.core.domain.BackpackDto; +import com.zy.acs.manager.manager.entity.AgvDetail; +import com.zy.acs.manager.manager.entity.Code; +import com.zy.acs.manager.manager.service.*; +import lombok.extern.slf4j.Slf4j; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.scheduling.annotation.Async; +import org.springframework.stereotype.Service; + +import java.util.ArrayList; +import java.util.Date; +import java.util.List; + +/** + * Created by vincent on 2023/6/16 + */ +@Slf4j +@Service +public class AgvDataNoCodeService { + + private final static Boolean PRINT_LOG = Boolean.FALSE; + + private final RedisSupport redis = RedisSupport.defaultRedisSupport; + + @Autowired + private AgvService agvService; + @Autowired + private AgvDetailService agvDetailService; + @Autowired + private CodeService codeService; + @Autowired + private WebsocketService websocketService; + @Autowired + private TrafficService trafficService; + @Autowired + private MapService mapService; + @Autowired + private ThreadPoolRegulator threadPoolRegulator; + @Autowired + private JamService jamService; + @Autowired + private AvoidWaveCalculator avoidWaveCalculator; + @Autowired + private FaultProcessor faultProcessor; + + @Async + public void dataProcess(AgvProtocol protocol) { + Date now = new Date(); + + IMessageBody msgBody = protocol.getMessageBody(); + assert msgBody != null; + + Long agvId = agvService.getAgvId(protocol.getAgvNo()); + if (null == agvId) { + log.warn("Agv [{}] 灏氭湭閴存潈 锛侊紒锛�", protocol.getAgvNo()); + return; + } + AgvDetail detail = agvDetailService.selectByAgvId(agvId); + if (null == detail) { + detail = new AgvDetail(); + detail.setAgvId(agvId); + if (!agvDetailService.save(detail)) { + log.error("Agv [{}] 璇︽儏鏇存柊澶辫触 锛侊紒锛�", protocol.getAgvNo()); + return; + } + } + detail.setUpdateTime(now); + + + // 鏃犵爜瀹炴椂鏁版嵁鍖� + if (msgBody instanceof AGV_13_UP) { + AGV_13_UP agv_13_up = (AGV_13_UP) msgBody; +// websocketService.agvInfoBroadcastWithOutPos(new WebsocketDto<AGV_13_UP>("agv", agv.getUuid(), agv_13_up)); + this.sync(agv_13_up, detail); +// redis.setObject(RedisConstant.DIGITAL_AGV_FLAG, agv.getUuid(), agv_13_up); + if (PRINT_LOG) { + log.info("Agv [{}] 鏃犵爜瀹炴椂鏁版嵁鍖� ===>> {}", protocol.getAgvNo(), JSON.toJSONString(agv_13_up)); + } + } + + if (!agvDetailService.updateById(detail)) { + log.error("Agv [{}] 璇︽儏鏇存柊澶辫触 锛侊紒锛�", protocol.getAgvNo()); + } + + } + + + // 鏃犵爜瀹炴椂鏁版嵁鍖� + private void sync(AGV_13_UP mesBody, AgvDetail detail) { + detail.setStatus(mesBody.getStatus()); + + Code code = codeService.getCacheByData(mesBody.getQrCode()); + if (null != code) { + + if (!detail.getAgvStatus().equals(AgvStatusType.CHARGE)) { + detail.setCode(null); + detail.setLastCode(code.getId()); + detail.setPos(0); + } else { + detail.setCode(code.getId()); + detail.setLastCode(null); + detail.setPos(1); + } + + + } else { + log.error("Agv [{}] 鏇存柊瀹氫綅鏁版嵁澶辫触 锛侊紒锛佷笂浼犳潯鐮侊細{}", agvService.getById(detail.getAgvId()).getUuid(), mesBody.getQrCode()); + } + + detail.setStraightVal((double) mesBody.getStraightDirectionPosition()); + + detail.setAgvAngle((double) mesBody.getAGVCurrentAngle()); + + detail.setGyroAngle((double) mesBody.getGyroAngle()); + + detail.setEncoderAngle((double) mesBody.getEncoderAngle()); + + detail.setHigh(mesBody.getCurrentAltitude()); + + detail.setSensorSts((long) mesBody.getSensorStatusFlags()); + + List<BackpackDto> backpackDtoList = new ArrayList<>(); + backpackDtoList.add(new BackpackDto(1, mesBody.isTempLoc1())); + backpackDtoList.add(new BackpackDto(2, mesBody.isTempLoc2())); + backpackDtoList.add(new BackpackDto(3, mesBody.isTempLoc3())); + backpackDtoList.add(new BackpackDto(4, mesBody.isTempLoc4())); + backpackDtoList.add(new BackpackDto(5, mesBody.isTempLoc5())); + backpackDtoList.add(new BackpackDto(6, mesBody.isTempLoc6())); + backpackDtoList.add(new BackpackDto(7, mesBody.isTempLoc7())); + detail.setBackpack(GsonUtils.toJson(backpackDtoList)); + + } + +} -- Gitblit v1.9.1