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

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  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. namespace WCS.WorkEngineering.Systems
  13. {
  14. /// <summary>
  15. /// 一楼入库工位处理系统
  16. /// </summary>
  17. [BelongTo(typeof(MainWorld))]
  18. [Description("一楼入库工位处理系统")]
  19. public class 一楼入库工位处理系统 : DeviceSystem<Station>
  20. {
  21. protected override bool ParallelDo => true;
  22. protected override bool SaveLogsToFile => true;
  23. private List<BCR> BCRS = new List<BCR>();
  24. public 一楼入库工位处理系统()
  25. {
  26. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  27. }
  28. public override void Do(Station obj)
  29. {
  30. obj.入库站点是否被禁止();
  31. obj.入库站点是否满足执行条件();
  32. WCS_TaskInfo task = null;//处理完成的任务
  33. try
  34. {
  35. SqlSugarHelper.Do(_db =>
  36. {
  37. var db = _db.Default;
  38. //获取RFID
  39. var barcode = BCRS.GetBCRCode(obj.Entity.Code);
  40. //跟据RFID获取对应的任务
  41. var taskInfo = db.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.Mid);
  42. if (taskInfo.Status != Entity.TaskStatus.AGVExecution)
  43. {
  44. if (db.Queryable<WCS_TaskDtl>().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货"))) return;
  45. else throw new KnownException($"任务:{taskInfo.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High);
  46. }
  47. if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库
  48. {
  49. //判断AGV任务目标地址是否是当前地址
  50. 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);
  51. if (taskInfo.AddrNext != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}不是货架上的任务,请检查RFID是否正确", LogLevelEnum.Mid);
  52. if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid);
  53. }
  54. //获取称重
  55. var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device<IStation91>(v, this.World)).FirstOrDefault();
  56. taskInfo.Weight = dev91.Data.Weight;
  57. if (taskInfo.Weight < 200) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid);
  58. //上抛重量
  59. try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); }
  60. taskInfo.Status = Entity.TaskStatus.ConveyorExecution;
  61. db.Updateable(taskInfo).ExecuteCommand();
  62. taskInfo.AddWCS_TASK_DTL(_db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货");
  63. task = taskInfo;
  64. });
  65. }
  66. catch (Exception ex)
  67. {
  68. throw new KnownException(ex.Message, LogLevelEnum.High);
  69. }
  70. obj.Data.TaskNumber = task.ID;
  71. obj.Data.VoucherNo++;
  72. }
  73. public override bool Select(Device dev)
  74. {
  75. return dev.HasFlag(DeviceFlags.一楼入库口);
  76. }
  77. }
  78. }