From f7686c71ac53f0d1bbd439bc0c898c86f7d68e34 Mon Sep 17 00:00:00 2001
From: dengjunjie <dengjunjie@hnkhzn.com>
Date: 星期一, 10 十一月 2025 16:39:10 +0800
Subject: [PATCH] 优化代码
---
项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs | 246 +++++++++++++++++++++++++++++++++++++------------
1 files changed, 185 insertions(+), 61 deletions(-)
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
index aff3ceb..e6b40d0 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ShuttleCarJob/ShuttleCarExtend/PartialTaskService.cs"
@@ -14,29 +14,47 @@
using WIDESEAWCS_Core.Helper;
using WIDESEAWCS_DTO.WMSInfo;
using WIDESEAWCS_Tasks.ShuttleCarJob;
+using System.Reflection.Metadata;
namespace WIDESEAWCS_Tasks
{
partial class CommonShuttleCarJob
{
+ private readonly object _lockObject = new object();
#region 鍫嗗灈鏈虹Щ杞﹀畬鎴�
/// <summary>
- /// 鑾峰彇鍫嗗灈鏈虹Щ杞�/绉诲簱鍏呯數浠诲姟
+ /// 鑾峰彇鍫嗗灈鏈哄畬鎴愮┛姊溅寰呮墽琛屼换鍔�
/// </summary>
public void GetSC_CarFinish()
{
- Dt_Task dt_Task = GetTask(TaskCarStatusEnum.SC_CarFinish.ObjToInt(), TaskOtherTypeEnum.RelocationCar.ObjToInt());//绉昏溅浠诲姟
+ #region 绉昏溅浠诲姟
+ Dt_Task dt_Task = GetTask(TaskCarStatusEnum.SC_CarFinish.ObjToInt(), TaskOtherTypeEnum.RelocationCar.ObjToInt());
if (dt_Task != null)
{
UpdateShuttleCar(dt_Task.ShuttleCarCode, dt_Task.CurrentAddress);
+ dt_Task.TaskState = TaskCarStatusEnum.RelocationCarFinish.ObjToInt();
_taskService.AddTask_Hty(dt_Task, TaskOperateTypeEnum.AutoComplete);
}
- dt_Task = GetTask(CarChargingTaskEnum.CarChargingSC_CarFinish.ObjToInt(), TaskOtherTypeEnum.RelocationCarCharging.ObjToInt());//绉昏溅鍏呯數浠诲姟
+ #endregion
+
+ #region 绉昏溅鍏呯數浠诲姟
+ dt_Task = GetTask(CarChargingTaskEnum.CarChargingSC_CarFinish.ObjToInt(), TaskOtherTypeEnum.RelocationCarCharging.ObjToInt());
if (dt_Task != null)
{
UpdateShuttleCar(dt_Task.ShuttleCarCode, dt_Task.CurrentAddress);
SendTask(dt_Task);//涓嬪彂鍏呯數浠诲姟
}
+ #endregion
+
+ #region 绉诲簱浠诲姟
+ dt_Task = GetTask(TaskRelocationStatusEnum.SC_RelocationFinish.ObjToInt(), TaskRelocationTypeEnum.Relocation.ObjToInt());
+ if (dt_Task != null) SendTask(dt_Task);
+ #endregion
+
+ #region 鍏ュ簱浠诲姟
+ dt_Task = _taskRepository.QueryFirst(x => _taskService.TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.SC_InFinish);
+ if (dt_Task != null) SendTask(dt_Task);
+ #endregion
}
#endregion
/// <summary>
@@ -47,21 +65,110 @@
public void UpdateShuttleCar(string ShuttleCarCode, string Address)
{
var ShuttleCar = QueryCode(ShuttleCarCode);
- string[] targetCodes = Address.Split("-");
- var Row = Convert.ToInt16(targetCodes[0]);
- if (Row == 3)
- {
- ShuttleCar.ShuttleCarPosition = Address;
- ShuttleCar.ShuttleCarPosition1 = Address;
- }
- else
- {
- //var a = Row == 1 ? 2.ToString("000") : 1.ToString("000");
- ShuttleCar.ShuttleCarPosition = Address;
- ShuttleCar.ShuttleCarPosition1 = Address;// a + "-" + targetCodes[1] + "-" + targetCodes[2];
- }
+ ShuttleCar.ShuttleCarPosition = Address;
+ ShuttleCar.ShuttleCarPosition1 = Address;
_shuttleCarService.UpdateData(ShuttleCar);
}
+
+ public void GetShuttleCarTask(ShuttleCar shuttleCar, ShuttleCarTaskCommandR command)
+ {
+ #region 鏂板缓绉昏溅鍏呯數浠诲姟
+ Dt_Task CarCharging_Task = GetTask((int)CarChargingTaskEnum.CarChargingNew, (int)TaskOtherTypeEnum.RelocationCarCharging);
+ if (CarCharging_Task != null)
+ {
+ Dt_Task? _Task = _taskRepository.QueryFirst(x => x.ShuttleCarCode == CarCharging_Task.ShuttleCarCode && x.TaskType != TaskOtherTypeEnum.RelocationCarCharging.ObjToInt());
+ if (_Task == null) SendTask(CarCharging_Task);
+ else if (_taskService.TaskOutboundTypes.Contains(_Task.TaskType) && _Task.TaskState >= TaskOutStatusEnum.SC_OutFinish.ObjToInt())
+ SendTask(CarCharging_Task);
+ }
+ #endregion
+
+ #region 鏂板缓绉昏溅浠诲姟璧风偣涓虹┖
+ Dt_Task? RelocationCar_Task = null;
+ lock (_lockObject)
+ {
+ RelocationCar_Task = GetTask((int)TaskCarStatusEnum.CarNew, (int)TaskOtherTypeEnum.RelocationCar);
+ if (RelocationCar_Task != null)
+ {
+ if (string.IsNullOrEmpty(RelocationCar_Task.SourceAddress))
+ {
+ (bool, Dt_ShuttleCar) result = GetSourceTask(shuttleCar, command);
+ if (result.Item1)
+ UpdateSource(ref RelocationCar_Task, result.Item2);
+ else
+ GetShuttleCar(ref RelocationCar_Task, shuttleCar);//鑾峰彇鍙﹀涓�涓┛姊溅淇℃伅
+ }
+ }
+ Thread.Sleep(1000);
+ }
+ #endregion
+
+ #region 鍫嗗灈鏈虹Щ搴撳畬鎴愬墠浠诲姟/鍫嗗灈鏈哄嚭搴撳畬鎴愬墠浠诲姟
+ //鍒ゆ柇鏄惁瀛樺湪婊¤冻鍫嗗灈鏈哄叆搴撶殑浠诲姟
+ if (_taskRepository.QueryFirst(x => _taskService.TaskInboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskInStatusEnum.Line_InFinish && !string.IsNullOrEmpty(x.NextAddress), _taskService.TaskOrderBy) == null)
+ {
+ Dt_Task dt_Task = _taskRepository.QueryFirst(x => _taskService.TaskRelocationTypes.Contains(x.TaskType) && x.TaskState < (int)TaskRelocationStatusEnum.SC_RelocationFinish, _taskService.TaskOrderBy) ??
+ _taskRepository.QueryFirst(x => _taskService.TaskOutboundTypes.Contains(x.TaskType) && x.TaskState < (int)TaskOutStatusEnum.SC_OutGetFinish, _taskService.TaskOrderBy);
+ if (dt_Task != null)
+ {
+ if (dt_Task.TaskState == (int)TaskRelocationStatusEnum.RelocationNew || dt_Task.TaskState == (int)TaskOutStatusEnum.OutNew)
+ {
+ var ShuttleCar = _shuttleCarService.QueryShuttleCar(dt_Task.SourceAddress);//鍒ゆ柇璧风偣鏄惁鏈夌┛姊溅
+ if (ShuttleCar == null)
+ {
+ if (RelocationCar_Task != null && string.IsNullOrEmpty(RelocationCar_Task.TargetAddress))
+ {
+ RelocationCar_Task.TargetAddress = dt_Task.SourceAddress;
+ RelocationCar_Task.NextAddress = dt_Task.SourceAddress;
+ _taskService.UpdateData(RelocationCar_Task);
+ _taskExecuteDetailService.AddTaskExecuteDetail(RelocationCar_Task.TaskNum, "鏇存柊绉昏溅浠诲姟鐩爣鍦板潃");
+ }
+ else
+ _taskService.AddRelocationCarTask("", dt_Task.SourceAddress);
+ }
+ else
+ {
+ dt_Task.ShuttleCarCode = ShuttleCar.ShuttleCarCode;
+ SendTask(dt_Task);
+ }
+ }
+ }
+ }
+ #endregion
+
+ #region 鏂板缓绉昏溅浠诲姟缁堢偣涓虹┖
+ if (RelocationCar_Task != null)
+ {
+ if (string.IsNullOrEmpty(RelocationCar_Task.TargetAddress))
+ {
+ #region 鍚慦MS鐢宠
+ var ShuttleCar = _shuttleCarService.QueryNoCode(RelocationCar_Task.ShuttleCarCode);
+ WebResponseContent content = new WebResponseContent();
+ var ResultData = HttpHelper.PostAsync(WMSInterfaceAddress.GetPosition + $"?position={RelocationCar_Task.SourceAddress}&&position1={ShuttleCar.ShuttleCarPosition}", "", headers: new Dictionary<string, string>());
+ if (ResultData.Result != null)
+ {
+ content = JsonConvert.DeserializeObject<WebResponseContent>(ResultData.Result);
+ if (content != null && content.Status)
+ {
+ RelocationCar_Task.TargetAddress = content.Message;
+ RelocationCar_Task.NextAddress = RelocationCar_Task.TargetAddress;
+ _taskService.UpdateData(RelocationCar_Task);
+ _taskExecuteDetailService.AddTaskExecuteDetail(RelocationCar_Task.TaskNum, "鏇存柊绉昏溅浠诲姟鐩爣鍦板潃");
+ }
+ }
+ #endregion
+ }
+ if (!string.IsNullOrEmpty(RelocationCar_Task.SourceAddress) && !string.IsNullOrEmpty(RelocationCar_Task.TargetAddress) && !string.IsNullOrEmpty(RelocationCar_Task.ShuttleCarCode))
+ {
+ Dt_Task? _Task = _taskRepository.QueryFirst(x => x.ShuttleCarCode == RelocationCar_Task.ShuttleCarCode && x.TaskType != TaskOtherTypeEnum.RelocationCar.ObjToInt());
+ if (_Task == null) SendTask(RelocationCar_Task);
+ else if (_taskService.TaskOutboundTypes.Contains(_Task.TaskType) && _Task.TaskState >= TaskOutStatusEnum.SC_OutFinish.ObjToInt())
+ SendTask(RelocationCar_Task);
+ }
+ }
+ #endregion
+ }
+
private static readonly SemaphoreSlim _CarTaskObject = new SemaphoreSlim(1, 1);
#region 鑾峰彇绉昏溅浠诲姟
/// <summary>
@@ -138,22 +245,23 @@
#endregion
#region 绌挎杞︿换鍔�
+
+ var task = _taskService.ShuttleCarRelocationTask(shuttleCar.DeviceCode);//鑾峰彇绌挎杞︾Щ搴撲换鍔�
+ if (task != null)
+ {
+ if (!task.SourceIsPickPlace && task.ShuttleCarCode == shuttleCar.DeviceCode)
+ {
+ SendTask(task);
+ }
+ }
else
{
- var task = _taskService.ShuttleCarRelocationTask(shuttleCar.DeviceCode);//鑾峰彇绌挎杞︾Щ搴撲换鍔�
+ task = _taskService.QueryShuttleCarTask(shuttleCar.DeviceCode);
if (task != null)
{
- if (!task.SourceIsPickPlace && task.ShuttleCarCode == shuttleCar.DeviceCode)
+ if (_taskService.TaskOutboundTypes.Contains(task.TaskType))
{
- SendTask(task);
- }
- }
- else
- {
- task = _taskService.QueryShuttleCarTask(shuttleCar.DeviceCode);
- if (task != null)
- {
- if (_taskService.TaskOutboundTypes.Contains(task.TaskType) && !task.SourceIsPickPlace)
+ if (!task.SourceIsPickPlace && task.TaskState == (int)TaskOutStatusEnum.OutNew)
{
var ShuttleCar = _shuttleCarService.QueryShuttleCar(task.SourceAddress);//鍑哄簱浠诲姟鍒ゆ柇璧风偣鏄惁鏈夌┛姊溅
if (ShuttleCar == null) _taskService.AddRelocationCarTask("", task.SourceAddress);
@@ -163,11 +271,12 @@
SendTask(task);
}
}
- else
- SendTask(task);
}
+ else
+ SendTask(task);
}
}
+
#endregion
}
catch (Exception)
@@ -197,6 +306,7 @@
_taskExecuteDetailService.AddTaskExecuteDetail(dt_Task.TaskNum, "鏇存柊绉昏溅浠诲姟璧峰鍦板潃");
}
#endregion
+
/// <summary>
/// 鍒ゆ柇褰撳墠绌挎杞︽槸鍚﹀彲浠ユ墽琛岀Щ搴�
/// </summary>
@@ -209,40 +319,50 @@
bool ok = false;
if (command.Status == (short)ShuttleCarStatus.Standby && command.TaskTypeComplete == (short)ShuttleCarTaskComplete.Standby && command.Err_Status == (short)ShuttleCarErr.Normal)
{
- #region 鍒ゆ柇褰撳墠绌挎杞︽槸鍚﹀瓨鍦ㄤ换鍔�
- Dt_Task? _Task = _taskRepository.QueryFirst(x => x.SourceAddress == _ShuttleCar.ShuttleCarPosition);
+ if (_taskRepository.QueryFirst(x => x.SourceAddress == _ShuttleCar.ShuttleCarPosition && _taskService.TaskRelocationTypes.Contains(x.TaskType) && x.TaskState == TaskRelocationStatusEnum.SC_RelocationExecuting.ObjToInt()) != null)
+ return (ok, _ShuttleCar);
+ Dt_Task? _Task = _taskRepository.QueryFirst(x => x.ShuttleCarCode == _ShuttleCar.ShuttleCarCode);
if (_Task != null)
- {
- if (_Task.TaskState == TaskOutStatusEnum.OutNew.ObjToInt() ||
- _Task.TaskState == TaskRelocationStatusEnum.RelocationNew.ObjToInt() ||
- _Task.TaskState == TaskCarStatusEnum.CarNew.ObjToInt() ||
- _Task.TaskState == CarChargingTaskEnum.CarChargingNew.ObjToInt())
- {
- _Task.ShuttleCarCode = shuttleCar.DeviceCode;
- SendTask(_Task);
- return (ok, _ShuttleCar);
- }
- }
- _Task = _taskRepository.QueryFirst(x => x.TargetAddress == _ShuttleCar.ShuttleCarPosition);
- if (_Task != null)
- {
- if (_Task.TaskState == TaskInStatusEnum.SC_InFinish.ObjToInt() ||
- _Task.TaskState == TaskRelocationStatusEnum.SC_RelocationFinish.ObjToInt() ||
- _Task.TaskState == CarChargingTaskEnum.CarChargingSC_CarFinish.ObjToInt())
- {
- _Task.ShuttleCarCode = shuttleCar.DeviceCode;
- SendTask(_Task);
- return (ok, _ShuttleCar);
- }
- }
- _Task = _taskRepository.QueryData(x => x.ShuttleCarCode == _ShuttleCar.ShuttleCarCode && _taskService.TaskOutboundTypes.Contains(x.TaskType)).OrderByDescending(x => x.CreateDate).FirstOrDefault();
- if (_Task != null)
- {
- if (_Task.TaskState >= TaskOutStatusEnum.SC_OutFinish.ObjToInt())
- _Task = null;
- }
- #endregion
+ ok = _taskService.TaskOutboundTypes.Contains(_Task.TaskType) && _Task.TaskState >= TaskOutStatusEnum.SC_OutFinish.ObjToInt();
ok = _Task == null;
+ #region 鍒ゆ柇褰撳墠绌挎杞︽槸鍚﹀瓨鍦ㄤ换鍔�
+ //Dt_Task? _Task = _taskRepository.QueryFirst(x => x.SourceAddress == _ShuttleCar.ShuttleCarPosition);
+ //if (_Task != null)
+ //{
+ // if (_Task.TaskState <= TaskOutStatusEnum.Car_OutFinish.ObjToInt() ||
+ // _Task.TaskState <= TaskRelocationStatusEnum.CarSource_Finish.ObjToInt() ||
+ // _Task.TaskState <= TaskCarStatusEnum.ShuttleCar_Finish.ObjToInt() ||
+ // _Task.TaskState <= CarChargingTaskEnum.CarCharging_Finish.ObjToInt())
+ // {
+ // //_Task.ShuttleCarCode = shuttleCar.DeviceCode;
+ // //SendTask(_Task);
+ // return (ok, _ShuttleCar);
+ // }
+ //}
+ //_Task = _taskRepository.QueryFirst(x => x.TargetAddress == _ShuttleCar.ShuttleCarPosition);
+ //if (_Task != null)
+ //{
+ // if (_Task.TaskState >= TaskInStatusEnum.Line_InFinish.ObjToInt() ||
+ // _Task.TaskState >= TaskRelocationStatusEnum.CarSource_Finish.ObjToInt() ||
+ // _Task.TaskState >= CarChargingTaskEnum.CarCharging_Finish.ObjToInt())
+ // {
+ // //_Task.ShuttleCarCode = shuttleCar.DeviceCode;
+ // //SendTask(_Task);
+ // return (ok, _ShuttleCar);
+ // }
+ //}
+ //_Task = _taskRepository.QueryData(x => x.SourceAddress == _ShuttleCar.ShuttleCarPosition &&
+ //x.TaskState < TaskRelocationStatusEnum.CarSource_Finish.ObjToInt() &&
+ //x.TaskType == TaskRelocationTypeEnum.Relocation.ObjToInt()).OrderByDescending(x => x.CreateDate).FirstOrDefault();
+ //if (_Task != null) return (ok, _ShuttleCar);
+ //_Task = _taskRepository.QueryData(x => x.ShuttleCarCode == _ShuttleCar.ShuttleCarCode && _taskService.TaskOutboundTypes.Contains(x.TaskType)).OrderByDescending(x => x.CreateDate).FirstOrDefault();
+ //if (_Task != null)
+ //{
+ // if (_Task.TaskState >= TaskOutStatusEnum.SC_OutFinish.ObjToInt())
+ // _Task = null;
+ //}
+ //ok = _Task == null;
+ #endregion
}
if (!ok)
{
@@ -364,10 +484,12 @@
{
case (int)TaskInboundTypeEnum.Inbound:
case (int)TaskInboundTypeEnum.PalletInbound:
+ case (int)TaskInboundTypeEnum.InQuality:
taskType = ShuttleCarTaskType.In;
break;
case (int)TaskOutboundTypeEnum.Outbound:
case (int)TaskOutboundTypeEnum.PalletOutbound:
+ case (int)TaskOutboundTypeEnum.OutQuality:
taskType = ShuttleCarTaskType.Out;
break;
case (int)TaskOtherTypeEnum.RelocationCar:
@@ -390,10 +512,12 @@
{
case (int)TaskInboundTypeEnum.Inbound:
case (int)TaskInboundTypeEnum.PalletInbound:
+ case (int)TaskInboundTypeEnum.InQuality:
state = (int)TaskInStatusEnum.Car_InExecuting;
break;
case (int)TaskOutboundTypeEnum.Outbound:
case (int)TaskOutboundTypeEnum.PalletOutbound:
+ case (int)TaskOutboundTypeEnum.OutQuality:
state = (int)TaskOutStatusEnum.Car_OutExecuting;
break;
case (int)TaskRelocationTypeEnum.Relocation:
--
Gitblit v1.9.3