From f510760823f431891a501cd556928e215702ddb7 Mon Sep 17 00:00:00 2001
From: zhangc <zc@123>
Date: 星期六, 19 四月 2025 13:36:11 +0800
Subject: [PATCH] 999

---
 src/main/java/com/zy/core/model/protocol/LiftProtocol.java |  300 +++++++++++++++++++++++++++++++++++++++++++----------------
 1 files changed, 218 insertions(+), 82 deletions(-)

diff --git a/src/main/java/com/zy/core/model/protocol/LiftProtocol.java b/src/main/java/com/zy/core/model/protocol/LiftProtocol.java
index cd00e23..4451b72 100644
--- a/src/main/java/com/zy/core/model/protocol/LiftProtocol.java
+++ b/src/main/java/com/zy/core/model/protocol/LiftProtocol.java
@@ -1,168 +1,304 @@
 package com.zy.core.model.protocol;
 
+import com.core.common.Cools;
+import com.core.common.SpringUtils;
+import com.zy.asrs.entity.BasLiftErr;
+import com.zy.asrs.service.BasLiftErrService;
+import com.zy.common.utils.RedisUtil;
+import com.zy.core.enums.LiftProtocolStatusType;
+import com.zy.core.enums.RedisKeyType;
 import lombok.Data;
 import lombok.extern.slf4j.Slf4j;
 
-/**
- * 鎻愬崌鏈�
- */
 @Slf4j
 @Data
-public class LiftProtocol {
+public class LiftProtocol implements Cloneable {
 
+    //**********************蹇呴』瀛樺湪灞炴��**********************
     /**
      * 鎻愬崌鏈哄彿
      */
-    private Short liftNo;
+    private Integer liftNo;
 
     /**
      * 浠诲姟鍙�
      */
-    private Short taskNo = 0;
+    private Integer taskNo;
 
     /**
-     * 灞�
+     * 鍥涘悜绌挎杞﹀彿
      */
-    private Short lev;
+    private Integer shuttleNo = 0;
 
     /**
-     * 鎻愬崌鏈洪攣瀹�
+     * 褰撳墠鎻愬崌鏈虹姸鎬侊紙鍐呴儴鑷垜缁存姢锛�
      */
-    private Boolean liftLock;
+    private Integer protocolStatus = -1;
 
     /**
-     * 浣嶇疆鍒拌揪鍙嶉
+     * 褰撳墠鎻愬崌鏈虹姸鎬佹灇涓�
      */
-    private Short positionArrivalFeedback;
+    private LiftProtocolStatusType protocolStatusType = LiftProtocolStatusType.NONE;
 
     /**
-     * 鍑嗗灏辩华
-     * 灏辩华涓�1锛屾湭灏辩华涓�0
+     * 妯″紡 => 鑷姩/鎵嬪姩
+     */
+    private Boolean model;
+
+    /**
+     * 杩愯鐘舵��
+     */
+    private Boolean run;
+
+    /**
+     * 灏辩华鐘舵��
      */
     private Boolean ready;
 
     /**
-     * 杩愯涓�
-     * 杩愯涓负1锛屾湭杩愯涓�0
+     * 鍓嶈秴闄�
      */
-    private Boolean running;
+    private Boolean frontOverrun;
 
     /**
-     * 鑱旀満/鍗曟満
-     * 鑱旀満涓�1锛屽崟鏈轰负0
+     * 鍚庤秴闄�
      */
-    private Boolean mode;
+    private Boolean backOverrun;
 
     /**
-     * 杈撻�佺嚎鍓嶇鍏夌數鏈夎揣
-     * 鏈夎揣涓�1锛屾棤璐т负0锛堝墠绔寚闈犺繎璐ф灦渚э級
+     * 宸﹁秴闄�
      */
-    private Boolean lineFrontHasStock;
+    private Boolean leftOverrun;
 
     /**
-     * 杈撻�佺嚎姝h浆鍙嶉
-     * 姝h浆杩愯涓�1锛屽惁鍒欎负0
+     * 鍙宠秴闄�
      */
-    private Boolean forwardRotationFeedback;
+    private Boolean rightOverrun;
 
     /**
-     * 杈撻�佺嚎鍙嶈浆鍙嶉
-     * 鍙嶈浆杩愯涓�1锛屽惁鍒欎负0
+     * 瓒呴珮
      */
-    private Boolean reverseFeedback;
+    private Boolean overHeight;
 
     /**
-     * 杈撻�佺嚎鐢垫満杩囪浇
-     * 杩囪浇涓�0锛屾甯镐负1
+     * 瓒呴噸
      */
-    private Boolean motorOverload;
+    private Boolean overWeight;
 
     /**
-     * 杈撻�佺嚎鏈鍏夌數鏈夎揣
-     * 鏈夎揣涓�1锛屾棤璐т负0
+     * 鏈夋墭鐩�
      */
-    private Boolean lineEndHasStock;
+    private Boolean hasTray;
 
     /**
-     * 杩涜緭閫佺嚎鍗℃墭鐩樻姤璀�
-     * 鎶ヨ涓�1锛屾湭鎶ヨ涓�0
+     * 鏈夊皬杞�
      */
-    private Boolean inConveyLineCardTrayAlarm;
+    private Boolean hasCar;
 
     /**
-     * 鍑鸿緭閫佺嚎鍗℃墭鐩樻姤璀�
-     * 鎶ヨ涓�1锛屾湭鎶ヨ涓�0
+     * 鏁呴殰
      */
-    private Boolean outConveyLineCardTrayAlarm;
+    private Boolean error;
 
     /**
-     * 骞冲彴浣嶇疆鍋忓樊鎶ヨ
-     * 鎶ヨ涓�1锛屾湭鎶ヨ涓�0
+     * 鏁呴殰鐮�
      */
-    private Boolean platPositionDeviationAlarm;
+    private String errorCode;
 
     /**
-     * 骞冲彴鎵煩鍋忓樊鎶ヨ
-     * 鎶ヨ涓�1锛屾湭鎶ヨ涓�0
+     * 浠诲姟鍦板潃
      */
-    private Boolean platTorqueDeviationAlarm;
+    private Short taskAddress;
 
     /**
-     * 骞冲彴鍥涘悜杞︽娴�
-     * 鏈夎溅涓�1锛屾棤杞︿负0
+     * 鐩殑鍦板潃
      */
-    private Boolean platShuttleCheck;
+    private Short distAddress;
 
     /**
-     * 鏈氨缁姸鎬�
-     * 1.	涓嶅湪鎸囧畾灞�
-     * 2.	鍥涜酱涓嶅悓姝�
-     * 3.	骞冲彴鍓嶉檺鍏夌數琚尅鍒帮紙闈犺繎璐ф灦锛�
-     * 4.	骞冲彴鍚庨檺鍏夌數琚尅鍒帮紙杩滅璐ф灦锛�
-     * 5.	骞冲彴涓婇檺浣嶆姤璀�
-     * 6.	骞冲彴涓嬮檺浣嶆姤璀�
-     * 7.	鐢垫煖鎬ュ仠鎶ヨ
-     * 8.	杈撻�佺嚎鍓嶉檺浣嶈鎸″埌锛堥潬杩戣揣鏋讹級
-     * 9.	杈撻�佺嚎鍚庨檺浣嶈鎸″埌锛堣繙绂昏揣鏋讹級
-     * 10.	瑙︽懜灞忕揣鎬ュ仠姝㈣鎸変笅
-     * 11.	鍥涜酱鍔ㄥ姏绾挎柇绾�
-     * 12.	鍗曟満妯″紡
-     * 13.	鍥涜酱鎶ヨ
-     * 14.	浣嶇疆鍋忓樊杩囧ぇ
-     * 15.	鎵煩鍋忓樊杩囧ぇ
-     * 16.	杈撻�佺嚎杩囪浇
-     * 17.	杩涙彁鍗囨満鍗℃墭鐩�
-     * 18.	鍑烘彁鍗囨満鍗℃墭鐩�
+     * 宸插畬鎴愮殑浠诲姟鍙�
      */
-    private Short notReady;
+    private String completeTaskNo;
 
     /**
-     * 浼烘湇1閿欒
+     * 灞�
      */
-    private Short servoError1;
+    private Integer lev;
 
     /**
-     * 浼烘湇2閿欒
+     * 浣滀笟鏍囪
      */
-    private Short servoError2;
+    private Boolean pakMk = true;
 
     /**
-     * 浼烘湇3閿欒
+     * 鎸囦护涓嬪彂鏃堕棿
      */
-    private Short servoError3;
+    private Long sendTime = 0L;
 
     /**
-     * 浼烘湇4閿欒
+     * 鏃ュ織閲囬泦鏃堕棿
      */
-    private Short servoError4;
+    private Long deviceDataLog = System.currentTimeMillis();
 
     /**
-     * 鎻愬崌鏈哄疄闄呴�熷害鍙嶉
+     * 鎵╁睍瀛楁
      */
-    private Short liftActualSpeed;
+    private Object extend;
 
-    public Short getLiftLockShortValue() {
-        return liftLock ? (short) 1 : (short) 0;
+    public String getRun$() {
+        if (this.run == null) {
+            return "鏈煡";
+        }
+
+        return this.run ? "杩愯涓�" : "绌洪棽";
+    }
+
+    public String getReady$() {
+        if (this.ready == null) {
+            return "鏈煡";
+        }
+
+        return this.ready ? "灏辩华" : "鏈氨缁�";
+    }
+
+    public String getModel$() {
+        if (this.model == null) {
+            return "鏈煡";
+        }
+
+        return this.model ? "鑷姩" : "鎵嬪姩";
+    }
+
+    public String getHasTray$() {
+        if (this.hasTray == null) {
+            return "鏈煡";
+        }
+
+        return this.hasTray ? "Y" : "N";
+    }
+
+    public String getHasCar$() {
+        if (this.hasCar == null) {
+            return "鏈煡";
+        }
+
+        return this.hasCar ? "Y" : "N";
+    }
+
+    public String getFrontOverrun$() {
+        if (this.frontOverrun == null) {
+            return "鏈煡";
+        }
+
+        return this.frontOverrun ? "Y" : "N";
+    }
+
+    public String getBackOverrun$() {
+        if (this.backOverrun == null) {
+            return "鏈煡";
+        }
+
+        return this.backOverrun ? "Y" : "N";
+    }
+
+    public String getLeftOverrun$() {
+        if (this.leftOverrun == null) {
+            return "鏈煡";
+        }
+
+        return this.leftOverrun ? "Y" : "N";
+    }
+
+    public String getRightOverrun$() {
+        if (this.rightOverrun == null) {
+            return "鏈煡";
+        }
+
+        return this.rightOverrun ? "Y" : "N";
+    }
+
+    public String getOverHeight$() {
+        if (this.overHeight == null) {
+            return "鏈煡";
+        }
+
+        return this.overHeight ? "Y" : "N";
+    }
+
+    public String getOverWeight$() {
+        if (this.overWeight == null) {
+            return "鏈煡";
+        }
+
+        return this.overWeight ? "Y" : "N";
+    }
+
+    public String getProtocolStatus$() {
+        if (this.protocolStatusType == null) {
+            return "鏈煡";
+        }
+
+        return this.protocolStatusType.desc;
+    }
+
+    /**
+     * 璁剧疆鎻愬崌鏈虹姸鎬�
+     */
+    public void setProtocolStatus(Integer status) {
+        this.protocolStatus = status;
+        this.protocolStatusType = LiftProtocolStatusType.get(status);
+    }
+
+    /**
+     * 璁剧疆鎻愬崌鏈虹姸鎬�
+     */
+    public void setProtocolStatus(LiftProtocolStatusType status) {
+        this.protocolStatus = status.id;
+        this.protocolStatusType = status;
+    }
+
+    public synchronized void setTaskNo(Integer taskNo) {
+        RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class);
+        if (null != redisUtil) {
+            redisUtil.set(RedisKeyType.LIFT_FLAG.key + this.liftNo, taskNo);
+            this.taskNo = taskNo;
+        }
+    }
+
+    public Integer getTaskNo() {
+        RedisUtil redisUtil = SpringUtils.getBean(RedisUtil.class);
+        if (null != redisUtil) {
+            Object o = redisUtil.get(RedisKeyType.LIFT_FLAG.key + this.liftNo);
+            if (!Cools.isEmpty(o)) {
+                this.taskNo = Integer.valueOf(String.valueOf(o));
+            }
+        }
+        return this.taskNo == null ? 0 : this.taskNo;
+    }
+
+    /**
+     * 閿欒鐮�
+     */
+    public String getErrCode$() {
+        if (this.errorCode == null) {
+            return "";
+        }
+        BasLiftErrService basLiftErrService = SpringUtils.getBean(BasLiftErrService.class);
+        BasLiftErr basLiftErr = basLiftErrService.selectById(this.errorCode);
+        if (basLiftErr == null) {
+            return String.valueOf(this.errorCode);
+        }
+        return basLiftErr.getErrName();
+    }
+
+    @Override
+    public LiftProtocol clone() {
+        try {
+            return (LiftProtocol) super.clone();
+        } catch (CloneNotSupportedException e) {
+            e.printStackTrace();
+        }
+        return null;
     }
 
 }

--
Gitblit v1.9.1