From 69ba128c58bfb9f5a79481e4997558aafc6f46c6 Mon Sep 17 00:00:00 2001 From: zjj <3272660260@qq.com> Date: 星期二, 23 九月 2025 15:21:51 +0800 Subject: [PATCH] # --- src/main/java/com/zy/core/action/ShuttleAction.java | 462 +++++++++------------------------------------------------ 1 files changed, 72 insertions(+), 390 deletions(-) diff --git a/src/main/java/com/zy/core/action/ShuttleAction.java b/src/main/java/com/zy/core/action/ShuttleAction.java index 4c2da6f..a44e675 100644 --- a/src/main/java/com/zy/core/action/ShuttleAction.java +++ b/src/main/java/com/zy/core/action/ShuttleAction.java @@ -121,9 +121,9 @@ News.info("[RCS Debug] Execute check command {},{}", shuttleNo, taskNo); //妫�娴嬪懡浠� - int checked = checkCommand(redisCommand, shuttleNo); + ShuttleCheckCommandResultType checked = checkCommand(redisCommand, shuttleNo); News.info("[RCS Debug] Execute check command complete {},{}", shuttleNo, taskNo); - if (checked == 0) { + if (checked.equals(ShuttleCheckCommandResultType.FAIL)) { return false; } @@ -140,7 +140,7 @@ //鍙栧嚭鍛戒护 ShuttleCommand command = null; - if (checked == 1) { + if (checked.equals(ShuttleCheckCommandResultType.SUCCESS)) { //闈炶繛缁寚浠わ紝闇�瑕佹娴嬩笂涓�鏉℃寚浠ゆ槸鍚﹀畬鎴� if (commandStep > 0) { ShuttleCommand lastCommand = commands.get(commandStep - 1); @@ -150,7 +150,7 @@ } command = commands.get(commandStep); - } else if (checked == 2) { + } else if (checked.equals(ShuttleCheckCommandResultType.SUCCESS_GO)) { //杩炵画鎸囦护鐩存帴鍙栨暟鎹� command = commands.get(commandStep); } @@ -185,7 +185,7 @@ return false;//鐢宠澶辫触 } - if (checked == 2) { + if (checked.equals(ShuttleCheckCommandResultType.SUCCESS_GO)) { nodes.remove(0); } @@ -240,31 +240,31 @@ * 妫�娴嬪懡浠� * 0:鏈�氳繃 1:閫氳繃 2:閫氳繃涓斿彲鎻愬墠涓嬪彂鎸囦护 */ - private int checkCommand(ShuttleRedisCommand redisCommand, Integer shuttleNo) { + private ShuttleCheckCommandResultType checkCommand(ShuttleRedisCommand redisCommand, Integer shuttleNo) { TrafficControlThread trafficControlThread = (TrafficControlThread) SlaveConnection.get(SlaveType.TrafficControl, 1); if(trafficControlThread == null){ - return 0; + return ShuttleCheckCommandResultType.FAIL; } ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, shuttleNo); if (shuttleThread == null) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } ShuttleProtocol shuttleProtocol = shuttleThread.getStatus(); if (shuttleProtocol == null) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } int commandStep = redisCommand.getCommandStep(); if (commandStep == 0) { - return 1;//绗竴鏉″懡浠ゆ棤闇�妫�娴� + return ShuttleCheckCommandResultType.SUCCESS;//绗竴鏉″懡浠ゆ棤闇�妫�娴� } ShuttleAssignCommand assignCommand = redisCommand.getAssignCommand(); List<ShuttleCommand> commands = assignCommand.getCommands(); if (commands.isEmpty()) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } boolean supportContinuously = false; @@ -291,18 +291,18 @@ //灏忚溅绉诲姩杩炵画涓嬪彂鎸囦护 if (assignCommand.getShuttleMoveCommandsContinuously()) { if (!supportContinuously) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } //绉诲姩鎸囦护 if(lastCommand.getMode() != ShuttleCommandModeType.MOVE.id) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } List<NavigateNode> nodes = lastCommand.getNodes(); NavigateNode startNode = nodes.get(0); if (!startNode.getLinePartAllowGo()) {//鐩寸嚎娈甸儴鍒嗭紝鍏佽鐩存帴琛岃蛋 - return 0; + return ShuttleCheckCommandResultType.FAIL; } //鐩寸嚎娈垫暟鎹爣璇� @@ -312,23 +312,23 @@ //鍙栨寚浠� ShuttleCommand currentCommand = commands.get(commandStep); if(currentCommand.getMode() != ShuttleCommandModeType.MOVE.id) { - return 0; + return ShuttleCheckCommandResultType.FAIL; } List<NavigateNode> currentNodes = currentCommand.getNodes(); NavigateNode currentStartNode = currentNodes.get(0); if(!currentStartNode.getLinePartAllowGo()) {//鐩寸嚎娈甸儴鍒嗭紝鍏佽鐩存帴琛岃蛋 - return 0; + return ShuttleCheckCommandResultType.FAIL; } if(currentStartNode.getLinePartFlag().equals(linePartFlag)) { //鏁版嵁鏍囪瘑涓�鑷� - return 2;//鍏佽灏忚溅绉诲姩杩炵画涓嬪彂鎸囦护 + return ShuttleCheckCommandResultType.SUCCESS_GO;//鍏佽灏忚溅绉诲姩杩炵画涓嬪彂鎸囦护 } } } - return 0; + return ShuttleCheckCommandResultType.FAIL; } } @@ -371,10 +371,10 @@ //鍒犻櫎redis redisUtil.del(RedisKeyType.SHUTTLE_WORK_FLAG.key + redisCommand.getWrkNo()); - return 0;//绂佹鍐嶄笅鍙戝懡浠� + return ShuttleCheckCommandResultType.FAIL;//绂佹鍐嶄笅鍙戝懡浠� } - return 1; + return ShuttleCheckCommandResultType.SUCCESS; } //妫�娴嬫洿鏂板懡浠ゅ畬鎴� @@ -565,7 +565,7 @@ return; } - if (shuttleThread.isRequireCharge()) { + if (!shuttleThread.isRequireCharge().equals(ShuttleRequireChargeType.NONE)) { return; } @@ -707,378 +707,60 @@ } } + public synchronized void demoModeRunLoc(Integer shuttleNo) { + Config demoModeRunLocConfig = configService.selectOne(new EntityWrapper<Config>().eq("code", "demoModeRunLoc")); + if (demoModeRunLocConfig == null) { + return; + } + + if (!demoModeRunLocConfig.getValue().equals("Y")) { + return; + } + + ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, shuttleNo); + if (shuttleThread == null) { + return; + } + + ShuttleProtocol shuttleProtocol = shuttleThread.getStatus(); + if (shuttleProtocol == null) { + return; + } + + if (!shuttleThread.isIdle()) { + return; + } + + LocMast targetLoc = null; + EntityWrapper<LocMast> wrapper = new EntityWrapper<>(); + wrapper.eq("lev1", Utils.getLev(shuttleProtocol.getCurrentLocNo())); + wrapper.notIn("loc_sts", "X"); + wrapper.isNull("loc_type"); + wrapper.last("ORDER BY RAND() LIMIT 1"); + for (int i = 0; i < 3; i++) { + LocMast locMast = locMastService.selectOne(wrapper); + if(locMast == null) { + continue; + } + + targetLoc = locMast; + break; + } + + if(targetLoc == null) { + return; + } + + boolean result = shuttleDispatchUtils.dispatchShuttle(null, targetLoc.getLocNo(), shuttleProtocol.getShuttleNo()); + if (result) { + targetLoc.setLocType("Y"); + locMastService.updateById(targetLoc); + } + } + public synchronized boolean clearPath(Integer shuttleNo) { return navigateMapUtils.clearPath(shuttleNo); } - -// //璺戝簱绋嬪簭 -// public synchronized void moveLoc(Integer shuttleNo) { -// ShuttleThread shuttleThread = (ShuttleThread) SlaveConnection.get(SlaveType.Shuttle, shuttleNo); -// if (shuttleThread == null) { -// return; -// } -// ShuttleProtocol shuttleProtocol = shuttleThread.getStatus(false); -// if (shuttleProtocol == null) { -// return; -// } -// -// //灏忚溅寮�鍚窇搴撴ā寮� -// if (!shuttleProtocol.getMoveLoc()) { -// return; -// } -// -// //灏忚溅绌洪棽 -// if (!shuttleThread.isIdle()) { -// return; -// } -// -// int lev = Utils.getLev(shuttleProtocol.getCurrentLocNo());//灏忚溅褰撳墠妤煎眰 -// -// if (shuttleProtocol.getMoveType() == 0) {//璺戣建閬� -// //鏍规嵁鍦板浘鏂瑰悜鍐冲畾璺憍鎴杫 -// Config config = configService.selectOne(new EntityWrapper<Config>() -// .eq("code", "direction_map") -// .eq("status", 1)); -// if (config == null) { -// //璺戝簱缁撴潫 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// String direction = config.getValue(); -// -// if (direction.equals("y")) {//璺憍杞存柟鍚戯紝璺戝畬x杞村啀鍒囨崲y杞� -// ArrayList<String> locs = new ArrayList<>(); -// for (int i = shuttleProtocol.getXCurrent(); i <= shuttleProtocol.getXTarget(); i++) { -// String locNo = Utils.getLocNo(i, shuttleProtocol.getYCurrent(), lev); -// locs.add(locNo); -// } -// -// List<LocMast> locList = locMastService.selectList(new EntityWrapper<LocMast>() -// .eq("loc_sts", LocStsType.O.toString()) -// .in("loc_no", locs)); -// if (locList.isEmpty()) { -// //绌哄簱浣� -// shuttleProtocol.setYCurrent(shuttleProtocol.getYCurrent() + 1); -// return; -// } -// -// LocMast start = locList.get(0); -// LocMast target = locList.get(locList.size() - 1); -// //鍒ゆ柇灏忚溅鏄惁鍦ㄨ捣鐐逛綅缃� -// if (!shuttleProtocol.getCurrentLocNo().equals(start.getLocNo())) {//涓嶅湪璧风偣浣嶇疆锛岃皟搴﹀幓璧风偣浣嶇疆 -// shuttleDispatcher.generateMoveTask(device, start.getLocNo()); -// }else { -// //鍦ㄨ捣鐐逛綅缃紝璋冨害鍘荤洰鏍囦綅缃� -// Task task = shuttleDispatcher.generateMoveTask(device, target.getLocNo()); -// if (task != null) { -// shuttleProtocol.setYCurrent(shuttleProtocol.getYCurrent() + 1);//鍒囨崲y杞� -// } -// -// if(shuttleProtocol.getYCurrent() > shuttleProtocol.getYTarget()) { -// //y杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// }else {//璺憏杞存柟鍚戯紝璺戝畬y杞村啀鍒囨崲x杞� -// ArrayList<String> locs = new ArrayList<>(); -// for (int i = shuttleProtocol.getYCurrent(); i <= shuttleProtocol.getYTarget(); i++) { -// String locNo = Utils.getLocNo(shuttleProtocol.getXCurrent(), i, lev); -// locs.add(locNo); -// } -// -// List<Loc> locList = locService.list(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getLocSts, LocStsType.O.val()) -// .in(Loc::getLocNo, locs)); -// if (locList.isEmpty()) { -// //绌哄簱浣� -// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1); -// return; -// } -// -// Loc start = locList.get(0); -// Loc target = locList.get(locList.size() - 1); -// //鍒ゆ柇灏忚溅鏄惁鍦ㄨ捣鐐逛綅缃� -// if (!shuttleProtocol.getCurrentLocNo().equals(start.getLocNo())) {//涓嶅湪璧风偣浣嶇疆锛岃皟搴﹀幓璧风偣浣嶇疆 -// shuttleDispatcher.generateMoveTask(device, start.getLocNo()); -// }else { -// //鍦ㄨ捣鐐逛綅缃紝璋冨害鍘荤洰鏍囦綅缃� -// Task task = shuttleDispatcher.generateMoveTask(device, target.getLocNo()); -// if (task != null) { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1);//鍒囨崲x杞� -// } -// -// if(shuttleProtocol.getXCurrent() > shuttleProtocol.getXTarget()) { -// //y杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// } -// -// } else if (shuttleProtocol.getMoveType() == 1) {//璺戝簱浣� -// //鏍规嵁鍦板浘鏂瑰悜鍐冲畾璺憍鎴杫 -// Dict dict = dictService.getOne(new LambdaQueryWrapper<Dict>() -// .eq(Dict::getFlag, "direction_map") -// .eq(Dict::getStatus, 1)); -// if (dict == null) { -// //璺戝簱缁撴潫 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// String direction = dict.getValue(); -// -// if (direction.equals("y")) {//璺憍杞存柟鍚戯紝璺戝畬x杞村啀鍒囨崲y杞� -// Integer xCurrent = shuttleProtocol.getXCurrent(); -// -// //鑾峰彇寰呰窇搴撲綅鍙� -// String locNo = Utils.getLocNo(xCurrent, shuttleProtocol.getYCurrent(), lev); -// Loc target = locService.getOne(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getLocNo, locNo) -// .eq(Loc::getLocSts, LocStsType.O.val()) -// .eq(Loc::getHostId, device.getHostId())); -// if (target == null || shuttleProtocol.getCurrentLocNo().equals(locNo)) {//搴撲綅涓嶅瓨鍦ㄦ垨灏忚溅宸插湪褰撳墠浣嶇疆 -// shuttleProtocol.setXCurrent(xCurrent + 1); -// if (shuttleProtocol.getXCurrent() > shuttleProtocol.getXTarget()) { -// //x杞磋窇瀹岋紝鍒囨崲y杞� -// shuttleProtocol.setXCurrent(shuttleProtocol.getXStart()); -// shuttleProtocol.setYCurrent(shuttleProtocol.getYCurrent() + 1); -// -// if(shuttleProtocol.getYCurrent() > shuttleProtocol.getYTarget()) { -// //y杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// return; -// } -// -// //璋冨害鍘诲簱浣� -// Task task = shuttleDispatcher.generateMoveTask(device, locNo); -// if (task == null) { -// return;//璋冨害澶辫触 -// } -// -// shuttleProtocol.setXCurrent(xCurrent + 1); -// if (shuttleProtocol.getXCurrent() > shuttleProtocol.getXTarget()) { -// //x杞磋窇瀹岋紝鍒囨崲y杞� -// shuttleProtocol.setXCurrent(shuttleProtocol.getXStart()); -// shuttleProtocol.setYCurrent(shuttleProtocol.getYCurrent() + 1); -// -// if(shuttleProtocol.getYCurrent() > shuttleProtocol.getYTarget()) { -// //y杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// -// }else {//璺憏杞存柟鍚戯紝璺戝畬y杞村啀鍒囨崲x杞� -// Integer yCurrent = shuttleProtocol.getYCurrent(); -// -// //鑾峰彇寰呰窇搴撲綅鍙� -// String locNo = Utils.getLocNo(shuttleProtocol.getXCurrent(), yCurrent, lev); -// Loc target = locService.getOne(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getLocNo, locNo) -// .eq(Loc::getLocSts, LocStsType.O.val()) -// .eq(Loc::getHostId, device.getHostId())); -// if (target == null || shuttleProtocol.getCurrentLocNo().equals(locNo)) {//搴撲綅涓嶅瓨鍦ㄦ垨灏忚溅宸插湪褰撳墠浣嶇疆 -// shuttleProtocol.setYCurrent(yCurrent + 1); -// if (shuttleProtocol.getYCurrent() > shuttleProtocol.getYTarget()) { -// //y杞磋窇瀹岋紝鍒囨崲x杞� -// shuttleProtocol.setYCurrent(shuttleProtocol.getYStart()); -// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1); -// -// if(shuttleProtocol.getXCurrent() > shuttleProtocol.getXTarget()) { -// //x杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// return; -// } -// -// //璋冨害鍘诲簱浣� -// Task task = shuttleDispatcher.generateMoveTask(device, locNo); -// if (task == null) { -// return;//璋冨害澶辫触 -// } -// -// shuttleProtocol.setYCurrent(yCurrent + 1); -// if (shuttleProtocol.getYCurrent() > shuttleProtocol.getYTarget()) { -// //y杞磋窇瀹岋紝鍒囨崲x杞� -// shuttleProtocol.setYCurrent(shuttleProtocol.getYStart()); -// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1); -// -// if(shuttleProtocol.getXCurrent() > shuttleProtocol.getXTarget()) { -// //x杞翠篃璺戝畬浜嗭紝缁撴潫璺戝簱 -// shuttleProtocol.setMoveLoc(false); -// shuttleProtocol.setMoveType(0); -// shuttleProtocol.setXStart(0); -// shuttleProtocol.setXTarget(0); -// shuttleProtocol.setXCurrent(0); -// shuttleProtocol.setYStart(0); -// shuttleProtocol.setYTarget(0); -// shuttleProtocol.setYCurrent(0); -// return; -// } -// } -// -// } -// } else if (shuttleProtocol.getMoveType() == 2) {//姣嶈建閬撳惊鐜窇 -// Integer xCurrent = shuttleProtocol.getXCurrent(); -// Integer yCurrent = shuttleProtocol.getYCurrent(); -// -// String locNo = Utils.getLocNo(xCurrent, yCurrent, lev); -// //璋冨害鍘荤洰鏍囦綅缃� -// if (shuttleProtocol.getCurrentLocNo().equals(locNo)) { -// if (yCurrent.equals(shuttleProtocol.getYStart())) { -// shuttleProtocol.setYCurrent(shuttleProtocol.getYTarget());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅 -// } else { -// shuttleProtocol.setYCurrent(shuttleProtocol.getYStart());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅 -// } -// } else { -// Task result = shuttleDispatcher.generateMoveTask(device, locNo); -// if (result != null) {//璋冨害鎴愬姛 -// if (yCurrent.equals(shuttleProtocol.getYStart())) { -// shuttleProtocol.setYCurrent(shuttleProtocol.getYTarget());//鍒囨崲搴撲綅 -// } else { -// shuttleProtocol.setYCurrent(shuttleProtocol.getYStart());//鍒囨崲搴撲綅 -// } -// } -// } -// } else if (shuttleProtocol.getMoveType() == 3) {//瀛愯建閬撳惊鐜窇 -// Integer xCurrent = shuttleProtocol.getXCurrent(); -// Integer yCurrent = shuttleProtocol.getYCurrent(); -// -// String locNo = Utils.getLocNo(xCurrent, yCurrent, lev); -// //璋冨害鍘荤洰鏍囦綅缃� -// if (shuttleProtocol.getCurrentLocNo().equals(locNo)) { -// if (xCurrent.equals(shuttleProtocol.getXStart())) { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXTarget());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅 -// } else { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXStart());//灏忚溅鍜岀洰鏍囦綅缃竴鑷达紝鍒囨崲搴撲綅 -// } -// } else { -// Task result = shuttleDispatcher.generateMoveTask(device, locNo); -// if (result != null) {//璋冨害鎴愬姛 -// if (xCurrent.equals(shuttleProtocol.getXStart())) { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXTarget());//鍒囨崲搴撲綅 -// } else { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXStart());//鍒囨崲搴撲綅 -// } -// } -// } -// } else if (shuttleProtocol.getMoveType() == 4) {//鍙栨斁璐� -// Integer xCurrent = shuttleProtocol.getXCurrent(); -// if (xCurrent > shuttleProtocol.getXTarget()) {//褰揦鍊煎ぇ浜嶺鐩爣鍊� -// shuttleProtocol.setXCurrent(shuttleProtocol.getXStart()); -// shuttleProtocol.setYCurrent(shuttleProtocol.getYStart()); -// return; -// } -// -// //鍒ゆ柇x杞磋揣浣嶆槸鍚︽斁婊� -// boolean flag = true; -// for (Loc loc : locService.list(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getHostId, device.getHostId()) -// .eq(Loc::getRow, xCurrent) -// .ge(Loc::getBay, shuttleProtocol.getYStart()) -// .le(Loc::getBay, shuttleProtocol.getYTarget()))) { -// if (loc.getLocSts() != LocStsType.F.val()) { -// flag = false;//鏈弧 -// break; -// } -// } -// if (flag) { -// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1); -// return; -// } -// -// //鎼滅储鏈夎揣搴撲綅 -// List<Loc> list = locService.list(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getLocSts, LocStsType.F.val()) -// .eq(Loc::getHostId, device.getHostId()) -// .notIn(Loc::getRow, xCurrent) -// .eq(Loc::getStatus, 1)); -// if (list.isEmpty()) { -// return; -// } -// -// Loc start = list.get(0); -// -// List<Loc> locList = locService.list(new LambdaQueryWrapper<Loc>() -// .eq(Loc::getHostId, device.getHostId()) -// .eq(Loc::getStatus, 1) -// .eq(Loc::getLocSts, LocStsType.O.val()) -// .eq(Loc::getRow, xCurrent) -// .orderByDesc(Loc::getBay) -// .orderByAsc(Loc::getRow)); -// if (locList.isEmpty()) { -// return; -// } -// -// Loc target = locList.get(0); -// if (target == null) { -// return; -// } -// -// //璋冨害鍘荤洰鏍囦綅缃� -// if (!shuttleProtocol.getCurrentLocNo().equals(target.getLocNo())) { -// Task task = shuttleDispatcher.generateManuaTakeMoveTask(device, start.getLocNo(), target.getLocNo()); -//// if(task != null) {//璋冨害鎴愬姛 -//// shuttleProtocol.setXCurrent(shuttleProtocol.getXCurrent() + 1); -//// } -// } -// } -// } private CommandResponse write(ShuttleCommand command, Integer shuttleNo) { CommandResponse response = new CommandResponse(false); -- Gitblit v1.9.1