From 522f6806cde91d524e196626fdfe5ab4b5e3c9e2 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 17 八月 2020 17:04:15 +0800
Subject: [PATCH] #
---
src/main/java/com/zy/asrs/domain/param/CrnOperatorParam.java | 14 +-
src/main/java/com/zy/asrs/controller/CrnController.java | 168 +++++++++++++++++++++++++++++++++++++++--
2 files changed, 166 insertions(+), 16 deletions(-)
diff --git a/src/main/java/com/zy/asrs/controller/CrnController.java b/src/main/java/com/zy/asrs/controller/CrnController.java
index f4914b9..cbc1d78 100644
--- a/src/main/java/com/zy/asrs/controller/CrnController.java
+++ b/src/main/java/com/zy/asrs/controller/CrnController.java
@@ -2,7 +2,9 @@
import com.alibaba.fastjson.JSON;
import com.core.annotations.ManagerAuth;
+import com.core.common.BaseRes;
import com.core.common.R;
+import com.core.exception.CoolException;
import com.zy.asrs.domain.enums.CrnStatusType;
import com.zy.asrs.domain.param.CrnOperatorParam;
import com.zy.asrs.domain.vo.CommandLogVo;
@@ -14,6 +16,7 @@
import com.zy.core.cache.OutputQueue;
import com.zy.core.cache.SlaveConnection;
import com.zy.core.enums.CrnModeType;
+import com.zy.core.enums.CrnTaskModeType;
import com.zy.core.enums.SlaveType;
import com.zy.core.model.CrnSlave;
import com.zy.core.model.Task;
@@ -162,11 +165,6 @@
return R.ok().add(str.toString());
}
- public static void main(String[] args) {
- for (int i =0; i<10; i++) {
-
- }
- }
/****************************************************************/
/************************** 鎵嬪姩鎿嶄綔 ******************************/
@@ -175,19 +173,130 @@
@ManagerAuth(memo = "鍏ュ簱")
@PostMapping("/operator/put")
public R crnPut(CrnOperatorParam param){
- return R.ok("鍏ュ簱鎴愬姛");
+ if (param.getCrnNo() == null) {
+ return R.error(BaseRes.PARAM);
+ }
+ for (CrnSlave crn : slaveProperties.getCrn()) {
+ // 鑾峰彇鍫嗗灈鏈轰俊鎭�
+ if (param.getCrnNo().equals(crn.getId())) {
+ CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
+ if (crnThread == null) {
+ break;
+ }
+ CrnProtocol crnProtocol = crnThread.getCrnProtocol();
+ if (crnProtocol == null) {
+ break;
+ }
+ // 绌洪棽鍒ゆ柇
+ if (crnProtocol.getStatusType().equals(com.zy.core.enums.CrnStatusType.IDLE) && crnProtocol.getTaskNo() == 0) {
+ CrnCommand command = new CrnCommand();
+ command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
+ command.setTaskNo((short) 0); // 宸ヤ綔鍙�
+ command.setAckFinish((short) 0); // 浠诲姟瀹屾垚纭浣�
+ command.setTaskMode(CrnTaskModeType.PAKIN); // 浠诲姟妯″紡
+ command.setSourcePosX(param.getSourceRow()); // 婧愬簱浣嶆帓
+ command.setSourcePosY(param.getSourceBay()); // 婧愬簱浣嶅垪
+ command.setSourcePosZ(param.getSourceLev()); // 婧愬簱浣嶅眰
+ command.setDestinationPosX(param.getRow()); // 鐩爣搴撲綅鎺�
+ command.setDestinationPosY(param.getBay()); // 鐩爣搴撲綅鍒�
+ command.setDestinationPosZ(param.getLev()); // 鐩爣搴撲綅灞�
+ if (!MessageQueue.offer(SlaveType.Crn, crn.getId(), new Task(2, command))) {
+ return R.error("鍛戒护涓嬪彂澶辫触");
+ } else {
+ return R.ok();
+ }
+ } else {
+ return R.error("鍫嗗灈鏈洪潪绌洪棽鐘舵��");
+ }
+ }
+ }
+ return R.error("鍫嗗灈鏈轰笉鍦ㄧ嚎");
}
@ManagerAuth(memo = "鍑哄簱")
@PostMapping("/operator/take")
public R crnTake(CrnOperatorParam param){
- return R.ok("鍑哄簱鎴愬姛");
+ if (param.getCrnNo() == null) {
+ return R.error(BaseRes.PARAM);
+ }
+ for (CrnSlave crn : slaveProperties.getCrn()) {
+ // 鑾峰彇鍫嗗灈鏈轰俊鎭�
+ if (param.getCrnNo().equals(crn.getId())) {
+ CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
+ if (crnThread == null) {
+ break;
+ }
+ CrnProtocol crnProtocol = crnThread.getCrnProtocol();
+ if (crnProtocol == null) {
+ break;
+ }
+ // 绌洪棽鍒ゆ柇
+ if (crnProtocol.getStatusType().equals(com.zy.core.enums.CrnStatusType.IDLE) && crnProtocol.getTaskNo() == 0) {
+ CrnCommand command = new CrnCommand();
+ command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
+ command.setTaskNo((short) 0); // 宸ヤ綔鍙�
+ command.setAckFinish((short) 0); // 浠诲姟瀹屾垚纭浣�
+ command.setTaskMode(CrnTaskModeType.PAKOUT); // 浠诲姟妯″紡
+ command.setSourcePosX(param.getSourceRow()); // 婧愬簱浣嶆帓
+ command.setSourcePosY(param.getSourceBay()); // 婧愬簱浣嶅垪
+ command.setSourcePosZ(param.getSourceLev()); // 婧愬簱浣嶅眰
+ command.setDestinationPosX(param.getRow()); // 鐩爣搴撲綅鎺�
+ command.setDestinationPosY(param.getBay()); // 鐩爣搴撲綅鍒�
+ command.setDestinationPosZ(param.getLev()); // 鐩爣搴撲綅灞�
+ if (!MessageQueue.offer(SlaveType.Crn, crn.getId(), new Task(2, command))) {
+ return R.error("鍛戒护涓嬪彂澶辫触");
+ } else {
+ return R.ok();
+ }
+ } else {
+ return R.error("鍫嗗灈鏈洪潪绌洪棽鐘舵��");
+ }
+ }
+ }
+ return R.error("鍫嗗灈鏈轰笉鍦ㄧ嚎");
}
@ManagerAuth(memo = "搴撲綅杞Щ")
@PostMapping("/operator/stockMove")
public R crnStockMove(CrnOperatorParam param){
- return R.ok("搴撲綅杞Щ鎴愬姛");
+ if (param.getCrnNo() == null) {
+ return R.error(BaseRes.PARAM);
+ }
+ for (CrnSlave crn : slaveProperties.getCrn()) {
+ // 鑾峰彇鍫嗗灈鏈轰俊鎭�
+ if (param.getCrnNo().equals(crn.getId())) {
+ CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
+ if (crnThread == null) {
+ break;
+ }
+ CrnProtocol crnProtocol = crnThread.getCrnProtocol();
+ if (crnProtocol == null) {
+ break;
+ }
+ // 绌洪棽鍒ゆ柇
+ if (crnProtocol.getStatusType().equals(com.zy.core.enums.CrnStatusType.IDLE) && crnProtocol.getTaskNo() == 0) {
+ CrnCommand command = new CrnCommand();
+ command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
+ command.setTaskNo((short) 0); // 宸ヤ綔鍙�
+ command.setAckFinish((short) 0); // 浠诲姟瀹屾垚纭浣�
+ command.setTaskMode(CrnTaskModeType.LOC_MOVE); // 浠诲姟妯″紡
+ command.setSourcePosX(param.getSourceRow()); // 婧愬簱浣嶆帓
+ command.setSourcePosY(param.getSourceBay()); // 婧愬簱浣嶅垪
+ command.setSourcePosZ(param.getSourceLev()); // 婧愬簱浣嶅眰
+ command.setDestinationPosX(param.getRow()); // 鐩爣搴撲綅鎺�
+ command.setDestinationPosY(param.getBay()); // 鐩爣搴撲綅鍒�
+ command.setDestinationPosZ(param.getLev()); // 鐩爣搴撲綅灞�
+ if (!MessageQueue.offer(SlaveType.Crn, crn.getId(), new Task(2, command))) {
+ return R.error("鍛戒护涓嬪彂澶辫触");
+ } else {
+ return R.ok();
+ }
+ } else {
+ return R.error("鍫嗗灈鏈洪潪绌洪棽鐘舵��");
+ }
+ }
+ }
+ return R.error("鍫嗗灈鏈轰笉鍦ㄧ嚎");
}
@ManagerAuth(memo = "绔欏埌绔�")
@@ -205,7 +314,18 @@
@ManagerAuth(memo = "鍥炲師鐐�")
@PostMapping("/operator/bacOrigin")
public R crnBacOrigin(CrnOperatorParam param){
- return R.ok("鍥炲師鐐规垚鍔�");
+ CrnCommand command = new CrnCommand();
+ command.setCrnNo(param.getCrnNo()); // 鍫嗗灈鏈虹紪鍙�
+ command.setTaskNo((short) 0); // 宸ヤ綔鍙�
+ command.setAckFinish((short) 0); // 浠诲姟瀹屾垚纭浣�
+ command.setTaskMode(CrnTaskModeType.LOC_MOVE); // 浠诲姟妯″紡
+ command.setSourcePosX(param.getSourceRow()); // 婧愬簱浣嶆帓
+ command.setSourcePosY(param.getSourceBay()); // 婧愬簱浣嶅垪
+ command.setSourcePosZ(param.getSourceLev()); // 婧愬簱浣嶅眰
+ command.setDestinationPosX(param.getRow()); // 鐩爣搴撲綅鎺�
+ command.setDestinationPosY(param.getBay()); // 鐩爣搴撲綅鍒�
+ command.setDestinationPosZ(param.getLev()); // 鐩爣搴撲綅灞�
+ return crnControl(command)?R.ok():R.error();
}
@ManagerAuth(memo = "浠诲姟瀹屾垚")
@@ -232,4 +352,34 @@
return R.ok("娓呴櫎鍛戒护鎴愬姛");
}
+ private boolean crnControl(CrnCommand command){
+ if (command.getCrnNo() == null) {
+ throw new CoolException("璇烽�夋嫨鍫嗗灈鏈�");
+ }
+ for (CrnSlave crn : slaveProperties.getCrn()) {
+ // 鑾峰彇鍫嗗灈鏈轰俊鎭�
+ if (command.getCrnNo().equals(crn.getId())) {
+ CrnThread crnThread = (CrnThread) SlaveConnection.get(SlaveType.Crn, crn.getId());
+ if (crnThread == null) {
+ throw new CoolException("鍫嗗灈鏈轰笉鍦ㄧ嚎");
+ }
+ CrnProtocol crnProtocol = crnThread.getCrnProtocol();
+ if (crnProtocol == null) {
+ throw new CoolException("鍫嗗灈鏈轰笉鍦ㄧ嚎");
+ }
+ // 绌洪棽鍒ゆ柇
+ if (crnProtocol.getStatusType().equals(com.zy.core.enums.CrnStatusType.IDLE) && crnProtocol.getTaskNo() == 0) {
+ if (MessageQueue.offer(SlaveType.Crn, crn.getId(), new Task(2, command))) {
+ return true;
+ } else {
+ throw new CoolException("鍛戒护涓嬪彂澶辫触");
+ }
+ } else {
+ throw new CoolException("鍫嗗灈鏈轰笉鍦ㄧ┖闂茬姸鎬�");
+ }
+ }
+ }
+ return false;
+ }
+
}
diff --git a/src/main/java/com/zy/asrs/domain/param/CrnOperatorParam.java b/src/main/java/com/zy/asrs/domain/param/CrnOperatorParam.java
index 0f360a9..ae0f47e 100644
--- a/src/main/java/com/zy/asrs/domain/param/CrnOperatorParam.java
+++ b/src/main/java/com/zy/asrs/domain/param/CrnOperatorParam.java
@@ -15,24 +15,24 @@
private Integer sourceStaNo;
// 婧愬簱浣�-鎺�
- private Integer sourceRow;
+ private Short sourceRow;
// 婧愬簱浣�-鍒�
- private Integer sourceBay;
+ private Short sourceBay;
// 婧愬簱浣�-灞�
- private Integer sourceLev;
+ private Short sourceLev;
// 鐩爣绔�
- private Integer staNo;
+ private Short staNo;
// 鐩爣搴撲綅-鎺�
- private Integer row;
+ private Short row;
// 鐩爣搴撲綅-鍒�
- private Integer bay;
+ private Short bay;
// 鐩爣搴撲綅-灞�
- private Integer lev;
+ private Short lev;
}
--
Gitblit v1.9.1