一楼入库工位处理系统.cs 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  1. using ServiceCenter.Logs;
  2. using ServiceCenter.SqlSugars;
  3. using System.ComponentModel;
  4. using WCS.Core;
  5. using WCS.Entity;
  6. using WCS.Entity.Protocol.BCR;
  7. using WCS.Entity.Protocol.Station;
  8. using WCS.WorkEngineering.Extensions;
  9. using WCS.WorkEngineering.WebApi.Controllers;
  10. using WCS.WorkEngineering.Worlds;
  11. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  12. using TaskStatus = WCS.Entity.TaskStatus;
  13. namespace WCS.WorkEngineering.Systems
  14. {
  15. /// <summary>
  16. /// 一楼入库工位处理系统
  17. /// </summary>
  18. [BelongTo(typeof(MainWorld))]
  19. [Description("一楼入库工位处理系统")]
  20. public class 一楼入库工位处理系统 : DeviceSystem<Station>
  21. {
  22. protected override bool ParallelDo => true;
  23. protected override bool SaveLogsToFile => true;
  24. private List<BCR> BCRS = new List<BCR>();
  25. public 一楼入库工位处理系统()
  26. {
  27. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  28. }
  29. public override void Do(Station obj)
  30. {
  31. obj.入库站点是否被禁止();
  32. obj.入库站点是否满足执行条件();
  33. WCS_TaskInfo task = null;//处理完成的任务
  34. try
  35. {
  36. SqlSugarHelper.Do(_db =>
  37. {
  38. var db = _db.Default;
  39. WCS_TaskInfo taskInfo = null;
  40. if (!obj.Data3.Status.HasFlag(StatusEunm.PH_Status) && obj.Data2.Request == 0) return;
  41. //判断是否有空轮初始化任务
  42. if (db.Queryable<WCS_TaskInfo>().Count(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code) > 1)
  43. {
  44. throw new KnownException($"{obj.Entity.Code}站台存在多个空轮初始化入库任务,请取消RFID不是站台实物的任务", LogLevelEnum.Mid);
  45. }
  46. taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.Type == TaskType.EmptyInit && v.Status == TaskStatus.WaitingToExecute && v.SrmStation == obj.Entity.Code);
  47. string barcode = "";
  48. //manlun
  49. if (taskInfo == null)
  50. {
  51. //获取RFID
  52. barcode = BCRS.GetBCRCode(obj.Entity.Code);
  53. //跟据RFID获取对应的任务
  54. taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务,请检查扫码是否异常", LogLevelEnum.Mid);
  55. if (taskInfo.Status != Entity.TaskStatus.AGVExecution)
  56. {
  57. if (db.Queryable<WCS_TaskDtl>().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货"))) return;
  58. else throw new KnownException($"任务:{taskInfo.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High);
  59. }
  60. if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库
  61. {
  62. //判断AGV任务目标地址是否是当前地址
  63. var agv = db.Queryable<WCS_AgvTaskInfo>().SplitTable(v => v.Take(2)).First(v => v.ID == taskInfo.AgvTaskID) ?? throw new KnownException($"任务{taskInfo.ID}未找到对应AGV任务", LogLevelEnum.Mid);
  64. if (taskInfo.AddrNext != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}不是货架上的任务,请检查RFID是否正确", LogLevelEnum.Mid);
  65. if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid);
  66. }
  67. //获取称重
  68. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  69. //if (obj.Entity.Code != "1117")
  70. //{
  71. taskInfo.Weight = dev91.Data.Weight;
  72. //}
  73. //else
  74. //{
  75. // taskInfo.Weight = 800;
  76. //}
  77. if (taskInfo.Weight < 130) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
  78. //上抛重量
  79. try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
  80. }
  81. else//空轮初始化任务
  82. {
  83. //获取称重
  84. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  85. //if (obj.Entity.Code != "1117")
  86. //{
  87. taskInfo.Weight = dev91.Data.Weight;
  88. //}
  89. //else
  90. //{
  91. // taskInfo.Weight = 200;
  92. //}
  93. //taskInfo.Weight = dev91.Data.Weight;
  94. if (taskInfo.Weight < 140) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
  95. //上抛重量
  96. try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
  97. }
  98. taskInfo.Status = Entity.TaskStatus.ConveyorExecution;
  99. db.Updateable(taskInfo).ExecuteCommand();
  100. taskInfo.AddWCS_TASK_DTL(_db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
  101. task = taskInfo;
  102. });
  103. }
  104. catch (Exception ex)
  105. {
  106. throw new KnownException(ex.Message, LogLevelEnum.High);
  107. }
  108. if (task == null) return;
  109. obj.Data.TaskNumber = task.ID;
  110. obj.Data.VoucherNo++;
  111. }
  112. public override bool Select(Device dev)
  113. {
  114. return dev.HasFlag(DeviceFlags.一楼入库口);
  115. }
  116. }
  117. }