From 5c246f877049ab0e832637954ddbdf44e35b8135 Mon Sep 17 00:00:00 2001
From: yanjinhui <3306209981@qq.com>
Date: 星期一, 31 三月 2025 17:10:42 +0800
Subject: [PATCH] 完成实时通信

---
 项目代码/WIDESEAWCS_Server 正式/ISerialPortService/ITorqueOpServer.cs           |    5 ++
 项目代码/WIDESEAWCS_Server 正式/SerialPortService/TorqueOpServer.cs             |    4 +
 项目代码/WIDESEAWCS_Server 正式/.vs/WIDESEAWCS_Server/v17/HierarchyCache.v1.txt |    0 
 项目代码/WIDESEAWCS_Server 正式/WIDESEAWCS_Server/appsettings.json              |    2 
 项目代码/WIDESEAWCS_Server 正式/WIDESEAWCS_Tasks/SerialPort/SerialPortJob.cs    |   91 ++++++++++++++++++++++++++++++++++++---------
 5 files changed, 80 insertions(+), 22 deletions(-)

diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/.vs/WIDESEAWCS_Server/v17/HierarchyCache.v1.txt" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/.vs/WIDESEAWCS_Server/v17/HierarchyCache.v1.txt"
index 8a56d30..2960500 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/.vs/WIDESEAWCS_Server/v17/HierarchyCache.v1.txt"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/.vs/WIDESEAWCS_Server/v17/HierarchyCache.v1.txt"
Binary files differ
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/ISerialPortService/ITorqueOpServer.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/ISerialPortService/ITorqueOpServer.cs"
index 9fac0a4..5607ada 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/ISerialPortService/ITorqueOpServer.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/ISerialPortService/ITorqueOpServer.cs"
@@ -19,15 +19,18 @@
         /// <returns></returns>
         WebResponseContent Checkvalue(GetTorDTO getTorDTO);
 
+       
+
         WebResponseContent AddTorqueOp(Dt_TorqueOp torqueOp);
 
         /// <summary>
-        /// 鍒ゆ柇op琛ㄤ腑杩欎釜鍊兼槸鍚︽湁璇ユ潯浠诲姟鐨勬暟鎹�
+        /// 鍒ゆ柇op琛ㄤ腑杩欎釜鍊兼槸鍚︽湁璇ユ潯浠诲姟鐨勬暟鎹�/缁欏墠绔繑鍥炲綋鍓峯p琛ㄤ腑鐨勫��
         /// </summary>
         /// <param name="takeid">浠诲姟鍙�</param>
         /// <param name="group">缁勫埆</param>
         /// <param name="setpunm">姝ラ</param>
         /// <returns></returns>
         WebResponseContent WhetherSaveValueData(string takeid,string group,int setpunm);
+     
     }
 }
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/TorqueOpServer.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/TorqueOpServer.cs"
index 2c60365..76111c3 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/TorqueOpServer.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/SerialPortService/TorqueOpServer.cs"
@@ -14,7 +14,7 @@
 
 namespace WIDESEAWCS_TaskInfoService
 {
-    public class TorqueOpServer : ServiceBase<Dt_TorqueOp, ITorqueOpRepository>,ITorqueOpServer
+    public class TorqueOpServer : ServiceBase<Dt_TorqueOp, ITorqueOpRepository>, ITorqueOpServer
     {
         private IProcessRepository _iprocessRepository;
         public TorqueOpServer(ITorqueOpRepository BaseDal, IProcessRepository iprocessRepository) : base(BaseDal)
@@ -95,5 +95,7 @@
                 return new WebResponseContent { Status = false, Message = "閿欒" + ex.Message };
             }
         }
+
+      
     }
 }
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Server/appsettings.json" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Server/appsettings.json"
index 2614333..41cf0f7 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Server/appsettings.json"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WIDESEAWCS_Server \346\255\243\345\274\217/WIDESEAWCS_Server/appsettings.json"
@@ -30,6 +30,6 @@
   "QuartzJobAutoStart": true,
   "PrintSql": false,
   "WebSocketEnable": true,
-  "WebSocketPort": 5000,
+  "WebSocketPort": 5174,
   "LogDeubgEnable": true
 }
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 bbb7260..e27d8df 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"
@@ -9,8 +9,10 @@
 using System.Threading.Tasks;
 using AutoMapper;
 using HslCommunication.WebSocket;
+using Microsoft.AspNetCore.Mvc.ApiExplorer;
 using Newtonsoft.Json;
 using Newtonsoft.Json.Linq;
+using OfficeOpenXml.FormulaParsing.Excel.Functions.DateTime;
 using OfficeOpenXml.FormulaParsing.Excel.Functions.Logical;
 using OfficeOpenXml.FormulaParsing.Excel.Functions.Math;
 using Quartz;
@@ -27,11 +29,12 @@
 using WIDESEAWCS_QuartzJob.DTO;
 using WIDESEAWCS_TaskInfoService;
 using WIDESEAWCS_Tasks.SerialPort;
+using static WIDESEAWCS_Tasks.SerialPortJob;
 
 namespace WIDESEAWCS_Tasks
 {
     [DisallowConcurrentExecution]
-    public class SerialPortJob : JobBase, IJob,IDisposable
+    public class SerialPortJob : JobBase, IJob, IDisposable
     {
         public void Dispose()
         {
@@ -60,9 +63,9 @@
         private readonly IPutakeServer _putakeServer;
         private readonly ITorqueOpServer _torqueOpServer;
 
-       static string takeid = ""; // 鍦ㄥ惊鐜紑濮嬪墠澹版槑 takeid
+        static string takeid = ""; // 鍦ㄥ惊鐜紑濮嬪墠澹版槑 takeid
 
-        public SerialPortJob(ITorqueOpServer torqueOpServer,IPutakeServer putakeServer,IProcessServer processServer, IPutakeRepository putakeRepository, IProcessRepository processRepository, ITorqueOpRepository torqueOpRepository, WebSocketServer webSocketContext)
+        public SerialPortJob(ITorqueOpServer torqueOpServer, IPutakeServer putakeServer, IProcessServer processServer, IPutakeRepository putakeRepository, IProcessRepository processRepository, ITorqueOpRepository torqueOpRepository, WebSocketServer webSocketContext)
         {
             _putakeRepository = putakeRepository;
             _processRepository = processRepository;
@@ -70,7 +73,7 @@
             _webSocketContext = webSocketContext;
             _processServer = processServer;
             _putakeServer = putakeServer;
-            _torqueOpServer= torqueOpServer;    
+            _torqueOpServer = torqueOpServer;
         }
 
 
@@ -83,7 +86,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())
@@ -92,9 +95,15 @@
                             if (deviceProtocolDetail != null)
                             {
                                 string group = item.DeviceProDataBlock;//缁勫埆
+
+                                ////2.璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
+                                //var process = _processServer.Getcircuit(group, takeid);
+
+
+                               
                                 if (group == "鐢垫皵" || group == "鍦版矡" || group == "鏈烘")
-                                { // **鏌ヨ浠诲姟淇℃伅涓�娆�**
-                                    var takeResponse = _putakeServer.PerformTasks(group);
+                                { // 鏌ヨ浠诲姟淇℃伅涓�娆�
+                                    var takeResponse = _putakeServer.PerformTasks(group);//鏌ユ壘浠诲姟鍒嗚В琛ㄨ繖鏉℃渶鏃╃殑鏁版嵁
                                     if (takeResponse == null || !takeResponse.Status)
                                     {
                                         Console.WriteLine($"浠诲姟鍒嗙骇琛ㄦ帴鍙i敊璇細{takeResponse?.Message}");
@@ -150,13 +159,46 @@
                                         //鎶婅繖鏉℃暟鎹彃鍏p琛ㄤ腑
                                         string group = item.DeviceProDataBlock; // 璁惧鎵�灞炵粍鍒�
                                         string devicecode = item.DeviceChildCode;//璁惧缂栧彿
-                                        string torqueValue = ExtractTorqueValue(receiveData);//璋冪敤杞�兼柟娉�
+                                       string torqueValue = ExtractTorqueValue(receiveData);//璋冪敤杞�兼柟娉�
                                         if (group == "鐢垫皵" || group == "鍦版矡" || group == "鏈烘")
                                         {
                                             if (takeid != null)
                                             {
+                                               
+
+                                                //web
+                                                var process = _processServer.Getcircuit(group, takeid);
+                                                //var list = JsonConvert.SerializeObject(process.Data);//搴忓垪鍖�
+                                                //var dataS= JsonConvert.DeserializeObject<ProcessData>(list);//瀛楃涓插弽搴忓垪鍖栦负鍗曚釜 ProcessData 瀵硅薄
+
+                                                var dataS = JsonConvert.DeserializeObject<ProcessData>(JsonConvert.SerializeObject(process.Data)); // 纭繚涓哄璞�
+                                                int setnum = dataS.proNow.SetpNum;
+
+                                                //瀛樺��
                                                 SaveTorqueOpData(group, devicecode, torqueValue, takeid);
+
+                                                //op
+                                                var opResponse = _torqueOpServer.WhetherSaveValueData(takeid, group, setnum);
+                                                //var jsonResponse = JsonConvert.SerializeObject(opResponse.Data);
+                                                var opData = JsonConvert.DeserializeObject<List<Dt_TorqueOp>>(JsonConvert.SerializeObject(opResponse.Data)); // 纭繚涓哄璞�
+
+
+
+                                                // 鍒涘缓鍓嶇闇�瑕佺殑鏁版嵁瀵硅薄
+                                                var responseData = new
+                                                {
+                                                    process = dataS,  // 宸ヨ壓琛�
+                                                    operation = opData // op琛�
+                                                };//杩斿洖褰撳墠宸ヨ壓姝ラ鍜宱p琛ㄤ腑婊¤冻鏉′欢鐨勫��
+
+                                               
+
+                                                //寤轰竴涓璞″皢鍏朵紶缁欏墠绔�/搴忓垪鍖栧苟鎺ㄩ�佺粰鍓嶇
+                                                string data = JsonConvert.SerializeObject(responseData);//杩欓噷serialPortDevice鏄亣璁炬湁杩欎釜瀵硅薄
+                                                _webSocketContext.PublishAllClientPayload(data);
                                             }
+                                           
+                                        
                                           
                                             item.DeviceProParamName = CommandType.None.ToString();
                                         }
@@ -171,10 +213,9 @@
                                 }
                             }
 
+                           
 
-                            //寤轰竴涓璞″皢鍏朵紶缁欏墠绔�
-                            //string data = JsonConvert.SerializeObject(serialPortDevice);//杩欓噷serialPortDevice鏄亣璁炬湁杩欎釜瀵硅薄
-                            //_webSocketContext.PublishAllClientPayload(data);
+
                         }
 
                     }
@@ -210,7 +251,7 @@
         }
 
 
-  
+
 
         /// <summary>
         /// 澶勭悊鐢垫皵浠诲姟閫昏緫锛屽彂閫佹壄鐭╂寚浠ゅ埌璁惧
@@ -219,13 +260,13 @@
         /// <param name="serialPortDevice">涓插彛璁惧</param>
         /// <param name="item">璁惧淇℃伅</param>
         /// <param name="deviceProtocolDetail">璁惧鍗忚璇︽儏</param>
-        private void ProcessElectricTask(string group, SerialPortDevice serialPortDevice, DeviceProDTO item, DeviceProtocolDetailDTO deviceProtocolDetail,string takeid)
+        private void ProcessElectricTask( string group, SerialPortDevice serialPortDevice, DeviceProDTO item, DeviceProtocolDetailDTO deviceProtocolDetail, string takeid)
         {
             //1.鑾峰彇褰撳墠浠诲姟鍙�  //IPutakeServer閲岄潰鐨勫緟鎵ц鐨勭涓�鏉′换鍔★紱
             //var take = _putakeRepository.QueryData(x => x.Grouptype == group)
             //    .OrderBy(x => x.Dispatchtime)
             //    .FirstOrDefault();
-           
+
 
             //2.璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
             var process = _processServer.Getcircuit(group, takeid);
@@ -310,7 +351,7 @@
                         }
                     }
                     //杩欓噷杩欎釜浠诲姟绗竴娆℃墽琛岋紝op琛ㄤ腑鑲畾鏄病鏈夋暟鎹殑锛屾墍鏈夌涓�娆″氨瑕佹妸宸ヨ壓琛ㄤ腑鐨勫�肩粰瀹�
-                    else if(!op.Any()&& torqueone!=0)//闃叉姝ラ涓�涓璽orqueone鐨勫�间负0瀵艰嚧鎶ラ敊
+                    else if (!op.Any() && torqueone != 0)//闃叉姝ラ涓�涓璽orqueone鐨勫�间负0瀵艰嚧鎶ラ敊
                     {
                         //璁惧��
                         var com = item.DeviceChildCode + deviceProtocolDetail.ProtocalDetailValue
@@ -323,7 +364,7 @@
                 {
                     Console.WriteLine("proNow 涓虹┖");
                 }
-            }
+        }
             else
             {
                 Console.WriteLine($"Getcireit鎺ュ彛閿欒锛歿process?.Message}");
@@ -348,10 +389,10 @@
         /// <summary>
         /// 瀛樺偍鎵煩鏁版嵁鍒� `op` 琛�
         /// </summary>
-        private void SaveTorqueOpData(string group, string devicecode, string torqueValue,string takeid)
+        private void SaveTorqueOpData(string group, string devicecode, string torqueValue, string takeid)
         {
-        
-            //璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
+
+            ////璋冪敤Getcircuit鎷垮埌褰撳墠姝ラ
             var process = _processServer.Getcircuit(group, takeid);
 
             if (process != null && process.Status)
@@ -384,5 +425,17 @@
                 }
             }
         }
+
+        public class TorqueOpData
+        {
+            /// <summary>
+            /// 杩斿洖
+            /// </summary>
+            public List<Dt_TorqueOp> TorList { get; set; }
+        }
+
+      
+
+
     }
 }

--
Gitblit v1.9.3