代码优化

This commit is contained in:
cbs 2025-06-04 17:01:13 +08:00
parent fc8c96e5c2
commit 4f6fd7d807
8 changed files with 56 additions and 14 deletions

View File

@ -3,6 +3,7 @@ package cn.iocoder.yudao.module.system.controller.admin.tool;
import cn.iocoder.yudao.framework.common.pojo.CommonResult; import cn.iocoder.yudao.framework.common.pojo.CommonResult;
import cn.iocoder.yudao.module.system.controller.admin.robot.vo.RobotInformationSaveReqVO; import cn.iocoder.yudao.module.system.controller.admin.robot.vo.RobotInformationSaveReqVO;
import cn.iocoder.yudao.module.system.controller.admin.tool.dto.SendMsgToMqttDTO;
import cn.iocoder.yudao.module.system.service.tool.ToolsService; import cn.iocoder.yudao.module.system.service.tool.ToolsService;
import io.swagger.v3.oas.annotations.Operation; import io.swagger.v3.oas.annotations.Operation;
import io.swagger.v3.oas.annotations.tags.Tag; import io.swagger.v3.oas.annotations.tags.Tag;
@ -55,4 +56,12 @@ public class ToolsController {
toolsService.simulationPose(); toolsService.simulationPose();
return success("同步完成"); return success("同步完成");
} }
@PostMapping("/sendMsgToMQTT")
@Operation(summary = "发送消息给MQTT")
@PermitAll
public CommonResult<String> sendMsgToMQTT( @RequestBody SendMsgToMqttDTO dto) {
toolsService.sendMsgToMQTT(dto);
return success("发送完成");
}
} }

View File

@ -0,0 +1,14 @@
package cn.iocoder.yudao.module.system.controller.admin.tool.dto;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
@Data
public class SendMsgToMqttDTO {
@Schema(description = "消息")
private String msg;
@Schema(description = "主题topic")
private String topic;
}

View File

@ -59,6 +59,7 @@ import java.time.LocalDateTime;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collections; import java.util.Collections;
import java.util.LinkedList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.stream.Collectors; import java.util.stream.Collectors;
@ -499,6 +500,7 @@ public class PathPlanningServiceImpl implements PathPlanningService {
*/ */
@Override @Override
public void pathPlanningMovePose(String message) { public void pathPlanningMovePose(String message) {
log.info("车辆即将行走的点位 :{}",message);
PathPlanningMovePoseVO robotStatusData = JSON.parseObject(message, PathPlanningMovePoseVO.class); PathPlanningMovePoseVO robotStatusData = JSON.parseObject(message, PathPlanningMovePoseVO.class);
String mac = robotInformationService.getMacByRobotNo(robotStatusData.getRobotNo()); String mac = robotInformationService.getMacByRobotNo(robotStatusData.getRobotNo());
String floorAreaKey = RobotTaskChcheConstant.ROBOT_FLOOR_AREA + mac; String floorAreaKey = RobotTaskChcheConstant.ROBOT_FLOOR_AREA + mac;
@ -546,13 +548,14 @@ public class PathPlanningServiceImpl implements PathPlanningService {
return; return;
} }
List<PositionMapItemDO> itemDOList = new ArrayList<>(); List<PositionMapItemDO> itemDOList = new LinkedList<>();
List<PositionMapItemDO> items = positionMapItemService.getPositionMapItemByMapAndType(positionMap.getId(), PositionMapItemEnum.STOP.getType()); List<PositionMapItemDO> items = positionMapItemService.getPositionMapItemByMapAndType(positionMap.getId(), PositionMapItemEnum.STOP.getType());
if (ObjectUtil.isEmpty(items) || items.size() < robots.size()) { if (ObjectUtil.isNotEmpty(items)) {
itemDOList.addAll(items);
}
if ( itemDOList.size() < robots.size()) {
List<PositionMapItemDO> itemPoses = positionMapItemService.getPositionMapItemByMapAndType(positionMap.getId(), PositionMapItemEnum.PATH.getType()); List<PositionMapItemDO> itemPoses = positionMapItemService.getPositionMapItemByMapAndType(positionMap.getId(), PositionMapItemEnum.PATH.getType());
itemDOList.addAll(itemPoses); itemDOList.addAll(itemPoses);
} else {
itemDOList = items;
} }
List<SimulationRobotPoseDTO> simulationList = new ArrayList<>(); List<SimulationRobotPoseDTO> simulationList = new ArrayList<>();

View File

@ -174,7 +174,8 @@ public class PositionMapItemServiceImpl extends ServiceImpl<PositionMapItemMappe
public List<PositionMapItemDO> getPositionMapItemByMapAndType(Long mapId, Integer type) { public List<PositionMapItemDO> getPositionMapItemByMapAndType(Long mapId, Integer type) {
return positionMapItemMapper.selectList(new LambdaQueryWrapperX<PositionMapItemDO>() return positionMapItemMapper.selectList(new LambdaQueryWrapperX<PositionMapItemDO>()
.eq(PositionMapItemDO::getPositionMapId, mapId) .eq(PositionMapItemDO::getPositionMapId, mapId)
.eq(PositionMapItemDO::getType, type)); .eq(PositionMapItemDO::getType, type)
.orderByDesc(PositionMapItemDO::getId));
} }
/** /**

View File

@ -506,6 +506,9 @@ public class RobotInformationServiceImpl extends ServiceImpl<RobotInformationMap
List<RobotDimensionsDTO> RobotDimensions = informationMapper.selectRobotDimensions(); List<RobotDimensionsDTO> RobotDimensions = informationMapper.selectRobotDimensions();
commonApi.commonMethod(RobotDimensions, PathPlanningTopicConstant.SEND_ROBOT_DIMENSIONS); commonApi.commonMethod(RobotDimensions, PathPlanningTopicConstant.SEND_ROBOT_DIMENSIONS);
String pose2dKey = RobotTaskChcheConstant.ROBOT_INFORMATION_POSE_BAT + robotInformationDO.getMacAddress();
redisUtil.del(pose2dKey);
redisUtil.del(key); redisUtil.del(key);
//地图相关 //地图相关
String floorAreaKey = RobotTaskChcheConstant.ROBOT_FLOOR_AREA + robotInformationDO.getMacAddress(); String floorAreaKey = RobotTaskChcheConstant.ROBOT_FLOOR_AREA + robotInformationDO.getMacAddress();

View File

@ -218,19 +218,20 @@ public class RobotPathPlanningServiceImpl implements RobotPathPlanningService {
List<PositionMapItemDO> robotMapItems = new ArrayList<>(); List<PositionMapItemDO> robotMapItems = new ArrayList<>();
if (ObjectUtil.isNotEmpty(existMapItems)) { if (ObjectUtil.isNotEmpty(existMapItems)) {
for (PositionMapItemDO positionMapItem : positionMapItems) { for (PositionMapItemDO positionMapItem : existMapItems) {
robotNos.removeIf(v -> v.equals(positionMapItem.getRobotNo())); if (ObjectUtil.isEmpty(robots)) {
if (UseStatusEnum.USEING.getType().equals(positionMapItem.getUseStatus())) { break;
continue;
} }
robotNos.removeIf(v -> v.equals(positionMapItem.getRobotNo()));
positionMapItem.setUseStatus(UseStatusEnum.PRE_OCCUPANCY.getType()); positionMapItem.setUseStatus(UseStatusEnum.PRE_OCCUPANCY.getType());
robotMapItems.add(positionMapItem); robotMapItems.add(positionMapItem);
positionMapItems.removeIf(v -> v.getId().equals(positionMapItem.getId()));
} }
} }
if (ObjectUtil.isNotEmpty(robotNos)) { if (ObjectUtil.isNotEmpty(robotNos)) {
List<PositionMapItemDO> emptyMapItems = positionMapItems.stream() List<PositionMapItemDO> emptyMapItems = positionMapItems.stream()
.filter(v -> ObjectUtil.isEmpty(v.getRobotNo())) .filter(v -> UseStatusEnum.FREE.getType().equals(v.getUseStatus()))
.collect(Collectors.toList()); .collect(Collectors.toList());
if (ObjectUtil.isNotEmpty(emptyMapItems)) { if (ObjectUtil.isNotEmpty(emptyMapItems)) {
for (PositionMapItemDO positionMapItem : emptyMapItems) { for (PositionMapItemDO positionMapItem : emptyMapItems) {
@ -250,11 +251,8 @@ public class RobotPathPlanningServiceImpl implements RobotPathPlanningService {
return; return;
} }
Map<String, PositionMapItemDO> positionMap =
robotMapItems.stream().collect(Collectors.toMap(PositionMapItemDO::getRobotNo, Function.identity()));
Map<Long, Long> sortMap = positionMapItems.stream().collect(Collectors.toMap(PositionMapItemDO::getId, PositionMapItemDO::getSortNum)); Map<Long, Long> sortMap = positionMapItems.stream().collect(Collectors.toMap(PositionMapItemDO::getId, PositionMapItemDO::getSortNum));
//机器人不能行走的区域 //机器人不能行走的区域
List<TaskRobotNoLimittationAreaDTO> robotNoLimitationArea = getRobotNoLimitationArea(robots); List<TaskRobotNoLimittationAreaDTO> robotNoLimitationArea = getRobotNoLimitationArea(robots);
Map<String, TaskRobotNoLimittationAreaDTO> robotNoLimittationAreaDTOMap = Map<String, TaskRobotNoLimittationAreaDTO> robotNoLimittationAreaDTOMap =
@ -296,7 +294,7 @@ public class RobotPathPlanningServiceImpl implements RobotPathPlanningService {
.build(); .build();
TaskRobotNoLimittationAreaDTO taskRobotNoLimittationAreaDTO = robotNoLimittationAreaDTOMap.get(v.getRobotNo()); TaskRobotNoLimittationAreaDTO taskRobotNoLimittationAreaDTO = robotNoLimittationAreaDTOMap.get(v.getRobotNo());
List<TaskRobotNoLimittationAreaDTO> robotNoLimitions = Arrays.asList(taskRobotNoLimittationAreaDTO); List<TaskRobotNoLimittationAreaDTO> robotNoLimitions = Collections.singletonList(taskRobotNoLimittationAreaDTO);
pathPlanning.setRobotNoLimitationAreaDTOS(robotNoLimitions); pathPlanning.setRobotNoLimitationAreaDTOS(robotNoLimitions);
String key = PathPlanningChcheConstant.PATH_PLANNING_TASK + pathPlanning.getOrderId(); String key = PathPlanningChcheConstant.PATH_PLANNING_TASK + pathPlanning.getOrderId();

View File

@ -1,5 +1,7 @@
package cn.iocoder.yudao.module.system.service.tool; package cn.iocoder.yudao.module.system.service.tool;
import cn.iocoder.yudao.module.system.controller.admin.tool.dto.SendMsgToMqttDTO;
import javax.servlet.http.HttpServletResponse; import javax.servlet.http.HttpServletResponse;
import javax.validation.Valid; import javax.validation.Valid;
import javax.validation.constraints.NotBlank; import javax.validation.constraints.NotBlank;
@ -14,4 +16,10 @@ public interface ToolsService {
String updateWarnCode(); String updateWarnCode();
void simulationPose(); void simulationPose();
/**
* 发送消息给MQTT
* @param dto
*/
void sendMsgToMQTT(SendMsgToMqttDTO dto);
} }

View File

@ -14,6 +14,7 @@ import cn.iocoder.yudao.module.system.constant.robot.RobotTopicConstant;
import cn.iocoder.yudao.module.system.controller.admin.config.dto.TaskOrderConfigDTO; import cn.iocoder.yudao.module.system.controller.admin.config.dto.TaskOrderConfigDTO;
import cn.iocoder.yudao.module.system.controller.admin.config.vo.CommonConfigVO; import cn.iocoder.yudao.module.system.controller.admin.config.vo.CommonConfigVO;
import cn.iocoder.yudao.module.system.controller.admin.tool.dto.CleanAgvDTO; import cn.iocoder.yudao.module.system.controller.admin.tool.dto.CleanAgvDTO;
import cn.iocoder.yudao.module.system.controller.admin.tool.dto.SendMsgToMqttDTO;
import cn.iocoder.yudao.module.system.dal.dataobject.config.CommonConfigDO; import cn.iocoder.yudao.module.system.dal.dataobject.config.CommonConfigDO;
import cn.iocoder.yudao.module.system.dal.dataobject.positionmap.PositionMapDO; import cn.iocoder.yudao.module.system.dal.dataobject.positionmap.PositionMapDO;
import cn.iocoder.yudao.module.system.dal.dataobject.positionmap.PositionMapItemDO; import cn.iocoder.yudao.module.system.dal.dataobject.positionmap.PositionMapItemDO;
@ -244,6 +245,11 @@ public class ToolsServiceImpl implements ToolsService {
} }
} }
@Override
public void sendMsgToMQTT(SendMsgToMqttDTO dto) {
commonApi.commonMethodStr(dto.getMsg(),dto.getTopic());
}
public void addWarnMsg() { public void addWarnMsg() {
RobotWarnMsgDO warnMsg = RobotWarnMsgDO.builder().warnLevel(4) RobotWarnMsgDO warnMsg = RobotWarnMsgDO.builder().warnLevel(4)