From 13b93182b70c276996b2d00de9497eb6843b072e Mon Sep 17 00:00:00 2001
From: Junjie <fallin.jie@qq.com>
Date: 星期三, 19 七月 2023 08:37:37 +0800
Subject: [PATCH] command write

---
 src/main/java/com/zy/core/thread/LiftThread.java |  105 +++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 87 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/zy/core/thread/LiftThread.java b/src/main/java/com/zy/core/thread/LiftThread.java
index 2504792..ecc4c64 100644
--- a/src/main/java/com/zy/core/thread/LiftThread.java
+++ b/src/main/java/com/zy/core/thread/LiftThread.java
@@ -244,6 +244,51 @@
         }
 
         command.setLiftNo(slave.getId().shortValue());
+        short[] array = getCommandArr(command);//鑾峰彇鍛戒护鎶ユ枃
+
+        try {
+            Thread.sleep(1000);//鍛戒护涓嬪彂鍓嶄紤鐪�1s
+        } catch (InterruptedException e) {
+            throw new RuntimeException(e);
+        }
+
+        OperateResult result = modbusTcpNet.Write("41088", array);
+        if (result != null && result.IsSuccess) {
+            News.info("鎻愬崌鏈哄懡浠や笅鍙慬id:{}] >>>>> {}", slave.getId(), JSON.toJSON(command));
+            OutputQueue.LIFT.offer(MessageFormat.format("銆恵0}銆慬id:{1}] >>>>> 鍛戒护涓嬪彂锛� {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(command)));
+
+            try {
+                Thread.sleep(1000);//鍛戒护涓嬪彂鍚庝紤鐪�
+            } catch (InterruptedException e) {
+                throw new RuntimeException(e);
+            }
+
+            for (int i = 0; i < 5; i++) {
+                readStatus();//閲嶆柊璇诲彇鐘舵��
+                if (liftProtocol.getRunning()) {
+                    break;
+                }
+
+                //鍒ゆ柇鏄惁杩愯涓紝濡備笉杩愯锛岄噸鏂颁笅鍙戝懡浠�
+                result = modbusTcpNet.Write("41088", array);
+                News.info("鎻愬崌鏈哄懡浠や笅鍙慬id:{}] >>>>> {},娆℃暟锛歿}", slave.getId(), JSON.toJSON(command), i);
+                OutputQueue.LIFT.offer(MessageFormat.format("銆恵0}銆慬id:{1}] >>>>> 鍛戒护涓嬪彂锛� {2},娆℃暟锛歿}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(command), i));
+                try {
+                    Thread.sleep(3000);//鍛戒护涓嬪彂鍚庝紤鐪�
+                } catch (InterruptedException e) {
+                    throw new RuntimeException(e);
+                }
+            }
+            return true;
+        } else {
+            OutputQueue.LIFT.offer(MessageFormat.format("銆恵0}銆戝啓鍏ユ彁鍗囨満plc鏁版嵁澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort()));
+            News.error("鍐欏叆鎻愬崌鏈簆lc鏁版嵁澶辫触 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
+            return false;
+        }
+    }
+
+    //鑾峰彇鍛戒护鎶ユ枃
+    private short[] getCommandArr(LiftCommand command) {
         // 寮�濮嬩换鍔�
         short[] array = new short[30];
         //寮�濮嬭繍琛�
@@ -284,23 +329,7 @@
             tmp[1] = array[1];
             array = tmp;
         }
-
-        try {
-            Thread.sleep(1000);//鍛戒护涓嬪彂鍓嶄紤鐪�1s
-        } catch (InterruptedException e) {
-            throw new RuntimeException(e);
-        }
-
-        OperateResult result = modbusTcpNet.Write("41088", array);;
-        if (result != null && result.IsSuccess) {
-            News.info("鎻愬崌鏈哄懡浠や笅鍙慬id:{}] >>>>> {}", slave.getId(), JSON.toJSON(command));
-            OutputQueue.LIFT.offer(MessageFormat.format("銆恵0}銆慬id:{1}] >>>>> 鍛戒护涓嬪彂锛� {2}", DateUtils.convert(new Date()), slave.getId(), JSON.toJSON(command)));
-            return true;
-        } else {
-            OutputQueue.LIFT.offer(MessageFormat.format("銆恵0}銆戝啓鍏ユ彁鍗囨満plc鏁版嵁澶辫触 ===>> [id:{1}] [ip:{2}] [port:{3}]", DateUtils.convert(new Date()), slave.getId(), slave.getIp(), slave.getPort()));
-            News.error("鍐欏叆鎻愬崌鏈簆lc鏁版嵁澶辫触 ===>> [id:{}] [ip:{}] [port:{}]", slave.getId(), slave.getIp(), slave.getPort());
-            return false;
-        }
+        return array;
     }
 
     //鍒嗛厤浠诲姟
@@ -375,6 +404,43 @@
         int size = commands.size();
         LiftAssignCommand assignCommand = redisCommand.getAssignCommand();
 
+        if (commandStep != 0) {
+            //鍒ゆ柇涓婁竴鏉℃寚浠ゆ槸鍚﹀畬鎴�
+            LiftCommand command = commands.get(commandStep - 1);
+            if (command.getRun().intValue() == 1) {
+                //鎻愬崌鏈哄崌闄嶅懡浠�
+                if (command.getDistPosition().intValue() == liftProtocol.getPositionArrivalFeedback().intValue()) {
+                    //鎻愬崌鏈虹洰鏍囨ゼ灞傚拰瀹為檯妤煎眰鐩稿悓锛屽垯璁ゅ畾鍛戒护瀹屾垚
+                    command.setComplete(true);
+                }
+            } else if (command.getRun().intValue() == 2 || command.getRun().intValue() == 3) {
+                //鏃犺揣姝h浆锛屾湁璐ф杞�
+                if (!liftProtocol.getForwardRotationFeedback()) {
+                    //杈撻�佺嚎姝h浆鍙嶉涓嶅湪杩愯涓紝璁ゅ畾鍛戒护瀹屾垚
+                    command.setComplete(true);
+                }
+            } else if (command.getRun().intValue() == 6 || command.getRun().intValue() == 7) {
+                //鏈夎揣鍙嶈浆锛屾棤璐у弽杞�
+                if (!liftProtocol.getReverseFeedback()) {
+                    //杈撻�佺嚎鍙嶈浆鍙嶉涓嶅湪杩愯涓紝璁ゅ畾鍛戒护瀹屾垚
+                    command.setComplete(true);
+                }
+            } else if (command.getRun().intValue() == 4) {
+                //杈撻�佺嚎鍋滄
+                if (!liftProtocol.getForwardRotationFeedback() && !liftProtocol.getReverseFeedback()) {
+                    //杈撻�佺嚎姝h浆鍙嶈浆閮戒笉鍦ㄨ繍琛屼腑锛岃瀹氬懡浠ゅ畬鎴�
+                    command.setComplete(true);
+                }
+            }
+            //浠诲姟鏁版嵁淇濆瓨鍒皉edis
+            redisUtil.set("lift_wrk_no_" + redisCommand.getWrkNo(), JSON.toJSONString(redisCommand));
+
+            if (!command.getComplete()) {
+                //涓婁竴鏉′换鍔℃湭瀹屾垚锛岀姝笅鍙戝懡浠�
+                return false;
+            }
+        }
+
         //鍙栧嚭鍛戒护
         LiftCommand command = commands.get(commandStep);
         if (command.getOperaStaNo() != null && command.getDevpId() != null) {
@@ -411,6 +477,7 @@
             //淇濆瓨鏁版嵁鍒版暟鎹簱鍋氭祦姘�
             BasLiftOptService liftOptService = SpringUtils.getBean(BasLiftOptService.class);
             if (liftOptService != null) {
+                short[] commandArr = getCommandArr(command);//鑾峰彇鍛戒护鎶ユ枃
                 BasLiftOpt opt = new BasLiftOpt(
                         redisCommand.getWrkNo().intValue(),
                         redisCommand.getLiftNo().intValue(),
@@ -418,7 +485,8 @@
                         null,
                         null,
                         null,
-                        JSON.toJSONString(command)
+                        JSON.toJSONString(command),
+                        JSON.toJSONString(commandArr)
                 );
                 liftOptService.insert(opt);
             }
@@ -558,6 +626,7 @@
      * 鍒濆鍖栨彁鍗囨満
      */
     private void initLift() {
+        this.connect();
         if (null == liftProtocol) {
             liftProtocol = new LiftProtocol();
         }

--
Gitblit v1.9.1