| | |
| | | import com.zy.acs.manager.common.domain.TaskDto; |
| | | import com.zy.acs.manager.common.domain.param.HandlerPublishParam; |
| | | import com.zy.acs.manager.common.exception.BusinessException; |
| | | import com.zy.acs.manager.common.utils.CommonUtil; |
| | | import com.zy.acs.manager.core.domain.AgvBackpackDto; |
| | | import com.zy.acs.manager.core.domain.Lane; |
| | | import com.zy.acs.manager.core.domain.TaskPosDto; |
| | |
| | | for (Task task : taskList) { |
| | | Agv agv = allocateService.execute(task); |
| | | if (null == agv) { |
| | | log.warn("Task[{}] has an issue, because it failed to checkout agv which is idle...", task.getSeqNum()); |
| | | // log.warn("Task[{}] has an issue, because it failed to checkout agv which is idle...", task.getSeqNum()); |
| | | continue; |
| | | } |
| | | task.setAgvId(agv.getId()); |
| | |
| | | // valid ----------------------------------------------- |
| | | Agv agv = agvService.getById(agvId); |
| | | if (!agvService.judgeEnable(agv.getId(), true)) { |
| | | throw new CoolException("AGV[" + agv.getUuid() + "]当前不可用..."); |
| | | return; |
| | | // throw new CoolException("AGV[" + agv.getUuid() + "]当前不可用..."); |
| | | } |
| | | if (!Cools.isEmpty(taskService.selectInSts(agvId, TaskStsType.ASSIGN, TaskStsType.PROGRESS))) { |
| | | throw new CoolException("AGV[" + agv.getUuid() + "]分配任务失败,已存在执行任务..."); |
| | |
| | | } |
| | | |
| | | // re-order by agv current position |
| | | Code currCode = codeService.getById(agvDetail.getRecentCode()); |
| | | Double[] currPosition = new Double[] {currCode.getX(), currCode.getY()}; |
| | | |
| | | List<TaskPosDto> theFirstOne = list.get(0); |
| | | List<TaskPosDto> theLastOne = list.get(list.size() - 1); |
| | | |
| | | if (list.size() == 1) { |
| | | TaskPosDto head = theFirstOne.get(0); |
| | | TaskPosDto tail = theFirstOne.get(theFirstOne.size() - 1); |
| | | |
| | | int distanceByHead = CommonUtil.calcDistance(currPosition, head.getXy()); |
| | | int distanceByTail = CommonUtil.calcDistance(currPosition, tail.getXy()); |
| | | |
| | | if (distanceByTail < distanceByHead) { |
| | | Collections.reverse(theFirstOne); |
| | | } |
| | | |
| | | } else { |
| | | TaskPosDto headOfFirst = theFirstOne.get(0); |
| | | TaskPosDto tailOfFirst = theFirstOne.get(theFirstOne.size() - 1); |
| | | |
| | | TaskPosDto headOfLast = theLastOne.get(0); |
| | | TaskPosDto tailOfLast = theLastOne.get(theLastOne.size() - 1); |
| | | |
| | | int distanceByHeadOfFirst = CommonUtil.calcDistance(currPosition, headOfFirst.getXy()); |
| | | int distanceByTailOfFirst = CommonUtil.calcDistance(currPosition, tailOfFirst.getXy()); |
| | | |
| | | int distanceByHeadOfLast = CommonUtil.calcDistance(currPosition, headOfLast.getXy()); |
| | | int distanceByTailOfLast = CommonUtil.calcDistance(currPosition, tailOfLast.getXy()); |
| | | |
| | | if (Math.min(distanceByHeadOfLast, distanceByTailOfLast) < Math.min(distanceByHeadOfFirst, distanceByTailOfFirst)) { |
| | | Collections.reverse(list); |
| | | |
| | | if (distanceByTailOfLast < distanceByHeadOfLast) { |
| | | Collections.reverse(theLastOne); |
| | | } |
| | | } else { |
| | | if (distanceByTailOfFirst < distanceByHeadOfFirst) { |
| | | Collections.reverse(theFirstOne); |
| | | } |
| | | } |
| | | } |
| | | // Code currCode = codeService.getById(agvDetail.getRecentCode()); |
| | | // Double[] currPosition = new Double[] {currCode.getX(), currCode.getY()}; |
| | | // |
| | | // List<TaskPosDto> theFirstOne = list.get(0); |
| | | // List<TaskPosDto> theLastOne = list.get(list.size() - 1); |
| | | // |
| | | // if (list.size() == 1) { |
| | | // TaskPosDto head = theFirstOne.get(0); |
| | | // TaskPosDto tail = theFirstOne.get(theFirstOne.size() - 1); |
| | | // |
| | | // int distanceByHead = CommonUtil.calcDistance(currPosition, head.getXy()); |
| | | // int distanceByTail = CommonUtil.calcDistance(currPosition, tail.getXy()); |
| | | // |
| | | // if (distanceByTail < distanceByHead) { |
| | | // Collections.reverse(theFirstOne); |
| | | // } |
| | | // |
| | | // } else { |
| | | // TaskPosDto headOfFirst = theFirstOne.get(0); |
| | | // TaskPosDto tailOfFirst = theFirstOne.get(theFirstOne.size() - 1); |
| | | // |
| | | // TaskPosDto headOfLast = theLastOne.get(0); |
| | | // TaskPosDto tailOfLast = theLastOne.get(theLastOne.size() - 1); |
| | | // |
| | | // int distanceByHeadOfFirst = CommonUtil.calcDistance(currPosition, headOfFirst.getXy()); |
| | | // int distanceByTailOfFirst = CommonUtil.calcDistance(currPosition, tailOfFirst.getXy()); |
| | | // |
| | | // int distanceByHeadOfLast = CommonUtil.calcDistance(currPosition, headOfLast.getXy()); |
| | | // int distanceByTailOfLast = CommonUtil.calcDistance(currPosition, tailOfLast.getXy()); |
| | | // |
| | | // if (Math.min(distanceByHeadOfLast, distanceByTailOfLast) < Math.min(distanceByHeadOfFirst, distanceByTailOfFirst)) { |
| | | // Collections.reverse(list); |
| | | // |
| | | // if (distanceByTailOfLast < distanceByHeadOfLast) { |
| | | // Collections.reverse(theLastOne); |
| | | // } |
| | | // } else { |
| | | // if (distanceByTailOfFirst < distanceByHeadOfFirst) { |
| | | // Collections.reverse(theFirstOne); |
| | | // } |
| | | // } |
| | | // } |
| | | |
| | | // generate travel |
| | | Travel travel = new Travel(); |