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