From 5a15fa73d5f6a39917013871a65eb11a8c013391 Mon Sep 17 00:00:00 2001
From: huangxiaoqiang <huangxiaoqiang@hnkhzn.com>
Date: 星期三, 05 十一月 2025 17:30:56 +0800
Subject: [PATCH] 1
---
项目代码/WCS/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGV/CommonAGVJob.cs | 187 ++++++++++++++++++++++++++++++++++++----------
1 files changed, 147 insertions(+), 40 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 c572a39..0d40e08 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"
@@ -1,4 +1,7 @@
锘縰sing HslCommunication;
+using Newtonsoft.Json;
+using Newtonsoft.Json.Linq;
+using OfficeOpenXml.FormulaParsing.Excel.Functions.Information;
using Quartz;
using System;
using System.Collections.Generic;
@@ -6,9 +9,16 @@
using System.Linq;
using System.Text;
using System.Threading.Tasks;
+using WIDESEAWCS_Common;
using WIDESEAWCS_Common.TaskEnum;
+using WIDESEAWCS_Core;
+using WIDESEAWCS_Core.Helper;
+using WIDESEAWCS_DTO.TaskInfo;
+using WIDESEAWCS_DTO.WMS;
+using WIDESEAWCS_ISystemServices;
using WIDESEAWCS_ITaskInfoRepository;
using WIDESEAWCS_ITaskInfoService;
+using WIDESEAWCS_Model.Models;
using WIDESEAWCS_QuartzJob;
using WIDESEAWCS_Tasks.ConveyorLineJob;
using WIDESEAWCS_Tasks.ElevatorJob;
@@ -20,19 +30,30 @@
{
private readonly ITaskRepository _taskRepository;
private readonly ITaskService _taskService;
- public CommonAGVJob(ITaskRepository taskRepository,ITaskService taskService)
+ private readonly ISys_ConfigService _sys_ConfigService;
+ public CommonAGVJob(ITaskRepository taskRepository,ITaskService taskService,ISys_ConfigService configService)
{
_taskRepository = taskRepository;
_taskService = taskService;
+ _sys_ConfigService = configService;
}
public Task Execute(IJobExecutionContext context)
{
+ var RelocationTask = _taskRepository.QueryData(x => _taskService.TaskAcrossFloorboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
+ if (RelocationTask.Count > 0)
+ {
+ foreach (var item in RelocationTask)
+ {
+ AGVSendTask(item);
+ }
+ }
+
#region AGV璺ㄦゼ灞備换鍔�
var AcrossFloorTask = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskAcrossFloorStatusEnum.CarryNew);
if (AcrossFloorTask != null)
{
- var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskAcrossFloorStatusEnum.CarryNew && x.TaskState < (int)TaskAcrossFloorStatusEnum.SecondCarryFinish);
+ var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskAcrossFloorStatusEnum.CarryNew && x.TaskState < (int)TaskAcrossFloorStatusEnum.EndAddressExecuting);
if(task == null)
{
CommonElevator? elevator = Storage.Devices.FirstOrDefault(x => x.DeviceCode == "TSJ1") as CommonElevator;
@@ -40,6 +61,7 @@
{
if (elevator.GetValue<ElevatorDBName, short>(ElevatorDBName.Model) == 1)
{
+ Relocation(AcrossFloorTask);
if (AcrossFloorTask.Floor == "1F")
{
elevator.SetValue(ElevatorDBName.FlagBit, Convert.ToInt16(1));
@@ -49,8 +71,9 @@
elevator.SetValue(ElevatorDBName.StartCommand, Convert.ToInt16(1));
_taskService.SendAgvTask("AAA", AcrossFloorTask.TaskNum);
- AcrossFloorTask.TaskState = (int)TaskAcrossFloorStatusEnum.FirstCarry;
- _taskRepository.UpdateData(AcrossFloorTask);
+ //AcrossFloorTask.TaskState = (int)TaskAcrossFloorStatusEnum.FirstCarry;
+ //_taskRepository.UpdateData(AcrossFloorTask);
+ _taskService.UpdateTaskStatusToNext(AcrossFloorTask.TaskNum);
}
else
{
@@ -61,8 +84,9 @@
elevator.SetValue(ElevatorDBName.StartCommand, Convert.ToInt16(1));
_taskService.SendAgvTask("DDD", AcrossFloorTask.TaskNum);
- AcrossFloorTask.TaskState = (int)TaskAcrossFloorStatusEnum.FirstCarry;
- _taskRepository.UpdateData(AcrossFloorTask);
+ //AcrossFloorTask.TaskState = (int)TaskAcrossFloorStatusEnum.FirstCarry;
+ //_taskRepository.UpdateData(AcrossFloorTask);
+ _taskService.UpdateTaskStatusToNext(AcrossFloorTask.TaskNum);
}
}
}
@@ -71,58 +95,48 @@
#endregion
#region AGV鍚屽眰鎼繍浠诲姟
- var Carry = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
+
+ Dt_Task Carry = _taskRepository.QueryFirst(x => _taskService.TaskAGVCarryboundStates.Contains(x.TaskState) && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
if (Carry != null)
{
- if (Carry.SourceAddress.Contains("XB001") || Carry.TargetAddress.Contains("XB001"))
- {
- _taskService.SendAgvTask("cattleCarry1", Carry.TaskNum);
- Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
- _taskRepository.UpdateData(Carry);
- }
- else if (Carry.Floor == "1F")
- {
- _taskService.SendAgvTask("forkAutoTemplate1", Carry.TaskNum);
- Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
- _taskRepository.UpdateData(Carry);
- }
- else
- {
- _taskService.SendAgvTask("cattleCarry1", Carry.TaskNum);
- Carry.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
- _taskRepository.UpdateData(Carry);
- }
+ Relocation(Carry);
+ AGVSendTask(Carry);
}
+
#endregion
#region 1妤糀GV鍏ュ簱浠诲姟
var InTask = _taskRepository.QueryFirst(x => x.TaskState == (int)TaskInStatusEnum.InNew);
if (InTask != null)
{
- var OutTask = _taskRepository.QueryFirst(x => x.TaskState >= (int)TaskOutStatusEnum.OutNew && x.TaskState <(int)TaskOutStatusEnum.AGV_OutExecuting);
- var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskInStatusEnum.InNew && x.TaskState < (int)TaskInStatusEnum.SC_InExecuting);
- if (OutTask == null && task == null)
+ CommonConveyorLine? conveyorLine = Storage.Devices.FirstOrDefault(x => x.DeviceCode == "1001") as CommonConveyorLine;
+ var OutTask = _taskRepository.QueryFirst(x => x.TaskState >= (int)TaskOutStatusEnum.OutNew && x.TaskState < (int)TaskOutStatusEnum.AGV_OutExecuting);
+ var task = _taskRepository.QueryFirst(x => x.TaskState > (int)TaskInStatusEnum.InNew && x.TaskState < (int)TaskInStatusEnum.SC_InFinish);
+ if (OutTask == null)
{
- CommonConveyorLine? conveyorLine = Storage.Devices.FirstOrDefault(x => x.DeviceCode == "1001") as CommonConveyorLine;
if (conveyorLine != null)
{
- bool IsWrite = false;
short InteractiveSignal = conveyorLine.GetValue<ConveyorLineDBName, short>(ConveyorLineDBName.InteractiveSignal, "LK001");
var structs = BitConverter.GetBytes(InteractiveSignal).Reverse().ToArray().ToBoolArray();
- if (structs[0])
+ if ((task != null && task.TaskState == (int)TaskInStatusEnum.SC_InExecuting && !structs[1]) || task == null)
{
- IsWrite = conveyorLine.Communicator.WriteNoRead("DB100.0", 0);
- Thread.Sleep(1000);
- IsWrite = conveyorLine.Communicator.WriteNoRead("DB100.0", 9999);
- if (!IsWrite)
+ bool IsWrite = false;
+
+ if (structs[0] && !structs[1])
{
- return Task.CompletedTask;
+ IsWrite = conveyorLine.Communicator.WriteNoRead("DB100.0", Convert.ToInt32(0));
+ Thread.Sleep(1000);
+ IsWrite = conveyorLine.Communicator.WriteNoRead("DB100.0", Convert.ToInt32(9999));
+ if (!IsWrite)
+ {
+ return Task.CompletedTask;
+ }
+ Relocation(InTask);
+ _taskService.SendAgvTask("LIFANG", InTask.TaskNum);
+
+ _taskService.UpdateTaskStatusToNext(InTask.TaskNum);
}
-
- _taskService.SendAgvTask("LIFANG", InTask.TaskNum);
-
- _taskService.UpdateTaskStatusToNext(InTask.TaskNum);
}
}
}
@@ -132,5 +146,98 @@
return Task.CompletedTask;
}
+
+ public void AGVSendTask(Dt_Task task)
+ {
+ if (task.SourceAddress.Contains("XB001") || task.TargetAddress.Contains("XB001"))
+ {
+ _taskService.SendAgvTask("cattleCarry1", task.TaskNum);
+ task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+ _taskRepository.UpdateData(task);
+ }
+ else if (task.Floor == "1F")
+ {
+ _taskService.SendAgvTask("forkAutoTemplate1", task.TaskNum);
+ task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+ _taskRepository.UpdateData(task);
+ }
+ else
+ {
+ _taskService.SendAgvTask("cattleCarry1", task.TaskNum);
+ task.TaskState = (int)TaskAGVCarryStatusEnum.AGV_CarryExecuting;
+ _taskRepository.UpdateData(task);
+ }
+ }
+
+
+ public void Relocation(Dt_Task? task)
+ {
+ var taskDto = new RequestTaskDto()
+ {
+ Position = task.SourceAddress,
+ PalletCode = task.PalletCode,
+ TaskNum = task.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)
+ {
+ task.ExceptionMessage = content.Message;
+ _taskRepository.UpdateData(task);
+ return;
+ }
+
+ // 鍙嶅簭鍒楀寲浠诲姟鏁版嵁
+ var taskDTO = JsonConvert.DeserializeObject<List<WMSTaskDTO>>(content.Data.ToString());
+ bool IsAddTask = false;
+ foreach (var t in taskDTO)
+ {
+ if (t.TaskNum == task.TaskNum)
+ {
+ IsAddTask = false;
+ break;
+ }
+ else
+ {
+ IsAddTask = true;
+ }
+ }
+ if (IsAddTask)
+ _taskService.ReceiveWMSTask(taskDTO);
+
+ var taskNew = _taskRepository.QueryData(x => _taskService.TaskRelocationboundTypes.Contains(x.TaskType) && x.TaskState == (int)TaskAGVCarryStatusEnum.CarryNew);
+ if (taskNew.Count > 0)
+ {
+ if (taskNew[0].Floor == "2F")
+ {
+ foreach (var item in taskNew.OrderBy(x => x.Grade).ToList())
+ {
+ AGVSendTask(item);
+ _taskService.UpdateTaskStatusToNext(item.TaskNum);
+ }
+ }
+ else
+ {
+ foreach (var item in taskNew.OrderByDescending(x => x.Grade).ToList())
+ {
+ AGVSendTask(item);
+ _taskService.UpdateTaskStatusToNext(item.TaskNum);
+ }
+ }
+ }
+ }
}
}
--
Gitblit v1.9.3