From 1be269037e8cff8043b8f046fec70509ebfd951c Mon Sep 17 00:00:00 2001 From: Junjie <fallin.jie@qq.com> Date: 星期一, 21 八月 2023 14:41:58 +0800 Subject: [PATCH] 小车手动管制操作 --- src/main/java/com/zy/core/model/protocol/NyShuttleProtocol.java | 65 ++++++++++++++++++++++++++++++-- 1 files changed, 61 insertions(+), 4 deletions(-) diff --git a/src/main/java/com/zy/core/model/protocol/NyShuttleProtocol.java b/src/main/java/com/zy/core/model/protocol/NyShuttleProtocol.java index f6cd422..dcde899 100644 --- a/src/main/java/com/zy/core/model/protocol/NyShuttleProtocol.java +++ b/src/main/java/com/zy/core/model/protocol/NyShuttleProtocol.java @@ -2,9 +2,11 @@ import com.alibaba.fastjson.JSON; import com.core.common.SpringUtils; +import com.zy.asrs.entity.BasShuttle; import com.zy.asrs.service.BasShuttleService; import com.zy.common.utils.NavigatePositionConvert; import com.zy.core.News; +import com.zy.core.enums.ShuttleErrorCodeType; import com.zy.core.enums.ShuttleProtocolStatusType; import com.zy.core.enums.ShuttleStatusType; import com.zy.core.model.command.ShuttleAssignCommand; @@ -189,6 +191,13 @@ * 闈炶嚜鍔ㄧ姸鎬佹椂闂磋鏃�(S) */ private Integer errTime; + + /** + * 鐙崰浠ょ墝 + * 鏈浠诲姟鍗犳嵁锛屼护鐗屼负0 + * 琚换鍔″崰鎹紝灏嗕换鍔″彿璧嬪�肩粰浠ょ墝 + */ + private Integer token = 0; //鎬婚噷绋嬫暟 @Data @@ -375,7 +384,7 @@ if (this.getPoint() == null) { return ""; } - return NavigatePositionConvert.xyzToLocNo(this.getPoint().getX(), this.getPoint().getY(), this.getPoint().getZ()); + return NavigatePositionConvert.nyXyzToLocNo(this.getPoint().getX(), this.getPoint().getY(), this.getPoint().getZ()); } public String getCoord$() { @@ -386,7 +395,7 @@ } public void setPoint(NyShuttlePointClass point) { - String locNo = NavigatePositionConvert.xyzToLocNo(point.getX(), point.getY(), point.getZ()); + String locNo = NavigatePositionConvert.nyXyzToLocNo(point.getX(), point.getY(), point.getZ()); this.point = point; this.currentLocNo = locNo; } @@ -394,7 +403,7 @@ // 鏄惁澶勪簬绌洪棽寰呭懡鐘舵�� public Boolean isIdle() { boolean res = this.free == ShuttleStatusType.IDLE.id - && this.pakMk.equals(true) + && !this.pakMk && this.errState == 0 && this.taskNo == 0 && this.protocolStatus == ShuttleProtocolStatusType.IDLE.id @@ -419,7 +428,7 @@ // 鏄惁澶勪簬绌洪棽寰呭懡鐘舵�侊紝浼犲叆鐨則askNo鍜屽綋鍓峵askNo鐩稿悓鏃跺厑璁告斁琛� public Boolean isIdle(int taskNo) { boolean res = this.free == ShuttleStatusType.IDLE.id - && this.pakMk.equals(true) + && !this.pakMk && this.errState == 0 && (this.taskNo == 0 || this.taskNo == taskNo) && this.protocolStatus.intValue() == ShuttleProtocolStatusType.IDLE.id @@ -438,4 +447,52 @@ } } + // 鏄惁澶勪簬绌洪棽寰呭懡鐘舵�� + public Boolean isIdleNoCharge() { + boolean res = this.free == ShuttleStatusType.IDLE.id + && !this.pakMk + && this.errState == 0 + && this.taskNo == 0 + && this.protocolStatus == ShuttleProtocolStatusType.IDLE.id + ; + return res; + } + + // 鏄惁婊¤冻鍏呯數鐘舵�� + public Boolean isRequireCharge() { + if (this.free == null || this.pakMk == null || this.errState == null || this.taskNo == null) { + return false; + } + + boolean res = this.free == ShuttleStatusType.IDLE.id + && !this.pakMk + && this.errState == 0 + && this.taskNo == 0 + && this.protocolStatusType.id == ShuttleProtocolStatusType.IDLE.id + ; + if (!res) { + return res; + } else { + // 鐢甸噺灏忎簬闃堝�兼垨鏈�浣庣數鑺數鍘嬪皬浜�2900mv锛岄渶瑕佽繘琛屽厖鐢� + try { + BasShuttleService shuttleService = SpringUtils.getBean(BasShuttleService.class); + if (shuttleService == null) { + return false; + + } + BasShuttle basShuttle = shuttleService.selectById(this.shuttleNo); + if (basShuttle == null) { + return false; + } + Integer chargeLine = basShuttle.getChargeLine(); + if (chargeLine == null) { + return false; + } + return this.getPowerPercent() < chargeLine || this.minCellVoltage < 2900; + } catch (Exception e) { + News.error("fail", e); + return false; + } + } + } } -- Gitblit v1.9.1