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