From 72fdccd147d416cd27c3374b25cb2f5896d86b6f Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期三, 26 三月 2025 11:35:19 +0800
Subject: [PATCH] 优化通信

---
 项目代码/WIDESEAWCS_Server 正式/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs |   78 ++++++++++++++++++++++++++------------
 1 files changed, 53 insertions(+), 25 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs"
index 94f6b98..bbb7260 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs"
@@ -58,8 +58,11 @@
         private WebSocketServer _webSocketContext;
         private readonly IProcessServer _processServer;
         private readonly IPutakeServer _putakeServer;
+        private readonly ITorqueOpServer _torqueOpServer;
 
-        public SerialPortJob(IPutakeServer putakeServer,IProcessServer processServer, IPutakeRepository putakeRepository, IProcessRepository processRepository, ITorqueOpRepository torqueOpRepository, WebSocketServer webSocketContext)
+       static string takeid = ""; // 鍦ㄥ惊鐜紑濮嬪墠澹版槑 takeid
+
+        public SerialPortJob(ITorqueOpServer torqueOpServer,IPutakeServer putakeServer,IProcessServer processServer, IPutakeRepository putakeRepository, IProcessRepository processRepository, ITorqueOpRepository torqueOpRepository, WebSocketServer webSocketContext)
         {
             _putakeRepository = putakeRepository;
             _processRepository = processRepository;
@@ -67,7 +70,10 @@
             _webSocketContext = webSocketContext;
             _processServer = processServer;
             _putakeServer = putakeServer;
+            _torqueOpServer= torqueOpServer;    
         }
+
+
 
         public Task Execute(IJobExecutionContext context)
         {
@@ -77,6 +83,7 @@
                 if (serialPortDevice != null)
                 {
                     List<DeviceProDTO> deviceProDTOs = serialPortDevice.DeviceProDTOs;
+                    
                     foreach (var item in deviceProDTOs)
                     {
                         if (item.DeviceProParamName != CommandType.Get.ToString() && item.DeviceProParamName != CommandType.Set.ToString())
@@ -84,11 +91,22 @@
                             DeviceProtocolDetailDTO? deviceProtocolDetail = serialPortDevice.DeviceProtocolDetailDTOs.FirstOrDefault(x => x.DeviceProParamName == nameof(CommandType) && x.ProtocolDetailType == nameof(CommandType.Set));
                             if (deviceProtocolDetail != null)
                             {
-                                string group = item.DeviceProDataBlock;
-                                
+                                string group = item.DeviceProDataBlock;//缁勫埆
                                 if (group == "鐢垫皵" || group == "鍦版矡" || group == "鏈烘")
-                                {
-                                    ProcessElectricTask(group, serialPortDevice, item, deviceProtocolDetail);
+                                { // **鏌ヨ浠诲姟淇℃伅涓�娆�**
+                                    var takeResponse = _putakeServer.PerformTasks(group);
+                                    if (takeResponse == null || !takeResponse.Status)
+                                    {
+                                        Console.WriteLine($"浠诲姟鍒嗙骇琛ㄦ帴鍙i敊璇細{takeResponse?.Message}");
+                                        continue;
+                                    }
+
+                                    var take = JsonConvert.DeserializeObject<Dt_Putake>(JsonConvert.SerializeObject(takeResponse.Data));
+                                    takeid = take?.Njtakeid; // 缂撳瓨浠诲姟鍙�
+                                    if (takeid != null)
+                                    {
+                                        ProcessElectricTask(group, serialPortDevice, item, deviceProtocolDetail, takeid);
+                                    }
                                 }
                                 item.DeviceProParamName = CommandType.None.ToString();
                             }
@@ -133,13 +151,13 @@
                                         string group = item.DeviceProDataBlock; // 璁惧鎵�灞炵粍鍒�
                                         string devicecode = item.DeviceChildCode;//璁惧缂栧彿
                                         string torqueValue = ExtractTorqueValue(receiveData);//璋冪敤杞�兼柟娉�
-
-
-                                      
-                                       
                                         if (group == "鐢垫皵" || group == "鍦版矡" || group == "鏈烘")
                                         {
-                                            SaveTorqueOpData(group, devicecode, torqueValue);
+                                            if (takeid != null)
+                                            {
+                                                SaveTorqueOpData(group, devicecode, torqueValue, takeid);
+                                            }
+                                          
                                             item.DeviceProParamName = CommandType.None.ToString();
                                         }
 
@@ -201,15 +219,15 @@
         /// <param name="serialPortDevice">涓插彛璁惧</param>
         /// <param name="item">璁惧淇℃伅</param>
         /// <param name="deviceProtocolDetail">璁惧鍗忚璇︽儏</param>
-        private void ProcessElectricTask(string group, SerialPortDevice serialPortDevice, DeviceProDTO item, DeviceProtocolDetailDTO deviceProtocolDetail)
+        private void ProcessElectricTask(string group, SerialPortDevice serialPortDevice, DeviceProDTO item, DeviceProtocolDetailDTO deviceProtocolDetail,string takeid)
         {
-            //鑾峰彇褰撳墠浠诲姟鍙�  //IPutakeServer閲岄潰鐨勫緟鎵ц鐨勭涓�鏉′换鍔★紱
-            var take = _putakeRepository.QueryData(x => x.Grouptype == group)
-                .OrderBy(x => x.Dispatchtime)
-                .FirstOrDefault();
-            var takeid = take?.Njtakeid;//鎷垮埌浠诲姟鍙�
+            //1.鑾峰彇褰撳墠浠诲姟鍙�  //IPutakeServer閲岄潰鐨勫緟鎵ц鐨勭涓�鏉′换鍔★紱
+            //var take = _putakeRepository.QueryData(x => x.Grouptype == group)
+            //    .OrderBy(x => x.Dispatchtime)
+            //    .FirstOrDefault();
+           
 
-            //璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
+            //2.璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
             var process = _processServer.Getcircuit(group, takeid);
 
             if (process != null && process.Status)
@@ -230,7 +248,18 @@
 
 
                     //鍒ゆ柇op琛ㄤ腑杩欎釜鍊兼槸鍚︽湁璇ユ潯浠诲姟鐨勬暟鎹�
-                    var op = _orqueOpRepository.QueryData(x => x.TakeId == takeid && x.GroupOp == group && x.ProcessSte == setpNum);
+                    //var op = _orqueOpRepository.QueryData(x => x.TakeId == takeid && x.GroupOp == group && x.ProcessSte == setpNum);
+                    // 3. 鏌ヨ鎵煩璁板綍
+                    var opResponse = _torqueOpServer.WhetherSaveValueData(takeid, group, setpNum);
+                    if (opResponse == null || !opResponse.Status || opResponse.Data == null)
+                    {
+                        Console.WriteLine($"WhetherSaveValueData鎺ュ彛閿欒锛歿opResponse?.Message}");
+                        return;
+                    }
+
+                    var op = JsonConvert.DeserializeObject<List<Dt_TorqueOp>>(JsonConvert.SerializeObject(opResponse.Data)); // 纭繚杞崲姝g‘
+
+
                     if (op.Any())//鍒ゆ柇鏄惁鏈夋暟鎹�
                     {
                         //鎵惧埌浜嗗氨瑕佸姣旂幇鍦╫p琛ㄤ腑鏈夊灏戞潯锛屾槸鍚﹀拰宸ヨ壓琛ㄤ腑鐨勭洰鏍囦竴鑷�
@@ -319,13 +348,9 @@
         /// <summary>
         /// 瀛樺偍鎵煩鏁版嵁鍒� `op` 琛�
         /// </summary>
-        private void SaveTorqueOpData(string group, string devicecode, string torqueValue)
+        private void SaveTorqueOpData(string group, string devicecode, string torqueValue,string takeid)
         {
-            var take = _putakeRepository.QueryData(x => x.Grouptype == group)
-                                                                .OrderBy(x => x.Dispatchtime)
-                                                                .FirstOrDefault();
-            var takeid = take?.Njtakeid;//鎷垮埌浠诲姟鍙�
-
+        
             //璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
             var process = _processServer.Getcircuit(group, takeid);
 
@@ -352,7 +377,10 @@
                         TorqueSize = float.TryParse(torqueValue, out float torque) ? torque : 0.0f, // 杩欓噷杩涜瀛楃涓插埌float鐨勮浆鎹�
                         CreateDate = DateTime.Now,
                     };
-                    _orqueOpRepository.AddData(Addop);
+                    //_orqueOpRepository.AddData(Addop);
+                    _torqueOpServer.AddData(Addop);
+
+
                 }
             }
         }

--
Gitblit v1.9.3