叫料生成AGV任务.cs 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101
  1. using Microsoft.OpenApi.Extensions;
  2. using ServiceCenter.Extensions;
  3. using ServiceCenter.Logs;
  4. using ServiceCenter.SqlSugars;
  5. using System;
  6. using System.Collections.Generic;
  7. using System.ComponentModel;
  8. using System.Linq;
  9. using System.Text;
  10. using System.Threading.Tasks;
  11. using WCS.Core;
  12. using WCS.Entity;
  13. using WCS.Entity.Protocol.Station;
  14. using WCS.WorkEngineering.Extensions;
  15. using WCS.WorkEngineering.WebApi.Controllers;
  16. using WCS.WorkEngineering.Worlds;
  17. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  18. using TaskStatus = WCS.Entity.TaskStatus;
  19. namespace WCS.WorkEngineering.Systems.重绕区
  20. {
  21. [BelongTo(typeof(RewindWorld))]
  22. [Description("叫料生成AGV任务")]
  23. public class 叫料生成AGV任务 : DeviceSystem<Device<IStation520, IStation521, IStation523>>
  24. {
  25. protected override bool ParallelDo => true;
  26. public override void Do(Device<IStation520, IStation521, IStation523> obj)
  27. {
  28. //if (!obj.Data3.Status.HasFlag(StationStatus.Auto))
  29. //{
  30. // World.Log($"设备处于{obj.Data3.Status.GetDisplayName()}状态");
  31. // return;
  32. //}
  33. if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status))
  34. {
  35. World.Log($"设备无光电");
  36. return;
  37. }
  38. SqlSugarHelper.Do(_db =>
  39. {
  40. var db = _db.Default;
  41. var task = db.Queryable<WCS_TaskInfo>().ReadPastUpdLock().Single(x => x.Status == TaskStatus.WaitingToExecute && x.AddrFrom == obj.Entity.Code
  42. && x.Type == TaskType.OutDepot);
  43. if (task == null)
  44. {
  45. World.Log($"未找到对应任务[{obj.Data.TaskNumber}],请检查该任务状态与更新状态是否均为输送机执行中", LogLevelEnum.High);
  46. return;
  47. }
  48. var agvId = DateTime.Now.GetFormat(GetFormatterEnum.only) + task.ID;
  49. //开始创建AGV任务
  50. var agvTask = db.Queryable<WCS_AgvTaskInfo>().RowLock().SplitTable(x => x.Take(2)).Single(x => x.TaskId == task.ID && x.TaskType == AGVTaskType.CallMaterial);
  51. if (agvTask == null)
  52. {
  53. //开始处理叫料AGV任务任务
  54. db.InsertableRowLock(new WCS_AgvTaskInfo()
  55. {
  56. ID = _db.GetAgvTaskId(),
  57. TaskType = AGVTaskType.CallMaterial,
  58. Status = AGVTaskStatus.NewBuild,
  59. TaskId = task.ID,
  60. Position = task.WorkBench,
  61. Station = task.AddrFrom,
  62. AddWho = "WCS",
  63. AddTime = DateTime.Now,
  64. AgvID = agvId
  65. }).SplitTable().ExecuteCommand();
  66. World.Log($"{task.ID}未找到对应的AGV任务");
  67. return;
  68. }
  69. if (agvTask.Status != AGVTaskStatus.NewBuild)
  70. {
  71. World.Log($"AGV任务{agvTask.ID}状态不是新建", LogLevelEnum.High);
  72. return;
  73. }
  74. agvId = agvTask.AgvID;
  75. //agvTask.AgvID = agvId;
  76. agvTask.Status = AGVTaskStatus.Confirm;
  77. agvTask.AgvStatus = AGVTaskStatus.Confirm;
  78. db.UpdateableRowLock(agvTask).UpdateColumns(x => new { x.AgvID, x.Status, x.AgvStatus }).SplitTable(x => x.Take(2)).ExecuteCommand();
  79. task.Status = TaskStatus.AGVExecution;
  80. task.AgvTaskID = agvTask.ID;
  81. task.EditTime = DateTime.Now;
  82. task.EditWho = "WCS";
  83. db.Updateable(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.EditTime, x.EditWho }).ExecuteCommand();
  84. task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务下发至AGV{agvId}");
  85. var res = AgvApi.重绕叫料(obj.Entity.Code, task.WorkBench, agvId);
  86. });
  87. }
  88. public override bool Select(Device dev)
  89. {
  90. return dev.HasFlag(DeviceFlags.重绕区叫料工位);
  91. }
  92. }
  93. }