From 82149871f30f4564d84272649352496a2ab0a38e Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期四, 23 十月 2025 17:12:52 +0800
Subject: [PATCH] 1
---
项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs | 115 +++------------------------------------------------------
1 files changed, 7 insertions(+), 108 deletions(-)
diff --git "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs" "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
index 7221859..a03904e 100644
--- "a/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
+++ "b/\351\241\271\347\233\256\344\273\243\347\240\201/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs"
@@ -49,13 +49,6 @@
}
}
- var taskCarry = _taskRepository.QueryData(x => x.TaskState == (int)TaskAcrossFloorStatusEnum.CarryNew);
- #region 鍑哄簱浠诲姟
-
- AGVOutTask(taskCarry.Where(x => x.TaskType.GetTaskTypeGroup() == TaskTypeGroup.OutbondGroup).ToList());
-
- #endregion
-
#region AGV璺ㄦゼ灞備换鍔�
var AcrossFloorTask = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskAcrossFloorStatusEnum.CarryNew);
if (AcrossFloorTask != null)
@@ -68,6 +61,7 @@
{
if (elevator.GetValue<ElevatorDBName, short>(ElevatorDBName.Model) == 1)
{
+ Relocation(AcrossFloorTask);
if (AcrossFloorTask.Floor == "1F")
{
elevator.SetValue(ElevatorDBName.FlagBit, Convert.ToInt16(1));
@@ -101,79 +95,11 @@
#region AGV鍚屽眰鎼繍浠诲姟
- Dt_Task Carry = null;
+ Dt_Task Carry = _taskRepository.QueryFirst(x => _taskService.TaskAGVCarryboundStates.Contains(x.TaskState) && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
if (Carry != null)
{
- var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskAGVCarryStatusEnum.CarryNew);
- if (task == null)
- {
- var taskDto = new RequestTaskDto()
- {
- Position = Carry.SourceAddress,
- PalletCode = Carry.PalletCode,
- TaskNum = Carry.TaskNum
- };
-
- // 鑾峰彇WMSip鍦板潃
- var configz = _sys_ConfigService.GetConfigsByCategory(CateGoryConst.CONFIG_SYS_IPAddress);
- var wmsBasez = configz.Where(x => x.ConfigKey == SysConfigKeyConst.WMSIP_BASE).FirstOrDefault()?.ConfigValue;
- var requestLocation = configz.Where(x => x.ConfigKey == SysConfigKeyConst.AGVIsNeedRelocation).FirstOrDefault()?.ConfigValue;
- if (wmsBasez == null || requestLocation == null)
- {
- throw new InvalidOperationException("WMS IP 鏈厤缃�");
- }
- var wmsIpAddrss = wmsBasez + requestLocation;
-
- var result = HttpHelper.PostAsync(wmsIpAddrss, taskDto.ToJsonString()).Result;
-
- WebResponseContent content = JsonConvert.DeserializeObject<WebResponseContent>(result);
-
- if (!content.Status)
- {
- Carry.ExceptionMessage = content.Message;
- _taskRepository.UpdateData(Carry);
- return null;
- }
-
- // 鍙嶅簭鍒楀寲浠诲姟鏁版嵁
- var taskDTO = JsonConvert.DeserializeObject<List<WMSTaskDTO>>(content.Data.ToString());
- bool IsAddTask = false;
- foreach (var t in taskDTO)
- {
- if (t.TaskNum == Carry.TaskNum)
- {
- IsAddTask = true;
- break;
- }
- else
- {
- IsAddTask = true;
- }
- }
- if (IsAddTask)
- _taskService.ReceiveWMSTask(taskDTO);
-
- var taskNew = _taskRepository.QueryData(x => x.TaskType == (int)TaskAGVCarryTypeEnum.CarryReloction && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
- if (taskNew.Count > 0)
- {
- if (taskNew[0].Remark == "2")
- {
- foreach (var item in taskNew.OrderBy(x => x.Grade).ToList())
- {
- AGVSendTask(item);
- }
- }
- else
- {
- foreach (var item in taskNew.OrderByDescending(x => x.Grade).ToList())
- {
- AGVSendTask(item);
- }
- }
- }
-
- AGVSendTask(Carry);
- }
+ Relocation(Carry);
+ AGVSendTask(Carry);
}
#endregion
@@ -201,7 +127,7 @@
{
return Task.CompletedTask;
}
-
+ Relocation(InTask);
_taskService.SendAgvTask("LIFANG", InTask.TaskNum);
_taskService.UpdateTaskStatusToNext(InTask.TaskNum);
@@ -214,32 +140,6 @@
return Task.CompletedTask;
}
-
- /// <summary>
- /// AGV鍑哄簱浠诲姟
- /// </summary>
- /// <param name="tasks"></param>
- public void AGVOutTask(List<Dt_Task> tasks)
- {
- if(tasks.Count > 0)
- {
- var OutTaskOneFloor = _taskRepository.QueryFirst(x => x.TaskState >= (int)TaskOutStatusEnum.OutNew && x.TaskState < (int)TaskOutStatusEnum.AGV_OutExecuting && x.Floor=="1F");
- var OutTaskTwoFloor = _taskRepository.QueryFirst(x => x.TaskState >= (int)TaskOutStatusEnum.OutNew && x.TaskState < (int)TaskOutStatusEnum.AGV_OutExecuting && x.Floor=="1F");
- if(OutTaskOneFloor == null)
- {
- var task = tasks.Where(x => x.Floor == "1F").OrderByDescending(x => x.Grade).FirstOrDefault();
- if (task != null)
- Relocation(task);
- }
- if (OutTaskTwoFloor == null)
- {
- var task = (tasks.Where(x => x.Floor == "2F").OrderBy(x => x.Grade).FirstOrDefault());
- if (task != null)
- Relocation(task);
- }
- }
- }
-
public void AGVSendTask(Dt_Task task)
{
@@ -319,18 +219,17 @@
{
foreach (var item in taskNew.OrderBy(x => x.Grade).ToList())
{
- //AGVSendTask(item);
+ AGVSendTask(item);
}
}
else
{
foreach (var item in taskNew.OrderByDescending(x => x.Grade).ToList())
{
- //AGVSendTask(item);
+ AGVSendTask(item);
}
}
}
- //AGVSendTask(task);
}
}
}
--
Gitblit v1.9.3