InboundSiteInteractionSystem.cs 2.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. using ServiceCenter.SqlSugars;
  2. using System.ComponentModel;
  3. using WCS.Core;
  4. using WCS.Entity;
  5. using WCS.Entity.Protocol.BCR;
  6. using WCS.WorkEngineering.Extensions;
  7. using WCS.WorkEngineering.Worlds;
  8. using WCS.WorkEngineering.Worlds.Logs;
  9. using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags;
  10. namespace WCS.WorkEngineering.Systems
  11. {
  12. /// <summary>
  13. /// 入站站点交互系统
  14. /// </summary>
  15. [BelongTo(typeof(MainWorld))]
  16. [Description("入站站点交互系统")]
  17. public class InboundSiteInteractionSystem : DeviceSystem<Station>
  18. {
  19. protected override bool ParallelDo => true;
  20. protected override bool SaveLogsToFile => true;
  21. private List<BCR> BCRS = new List<BCR>();
  22. public InboundSiteInteractionSystem()
  23. {
  24. BCRS = Device.All.Where(v => v.HasProtocol<IBCR81>()).Select(v => new BCR(v, World)).ToList();
  25. }
  26. public override void Do(Station obj)
  27. {
  28. obj.StorageStationIsForbid();
  29. //判断凭证号是否一致
  30. if (obj.Data.VoucherNo != obj.Data2.VoucherNo) throw new KnownException($"凭证号不一致,DB520:{obj.Data.VoucherNo}-DB521{obj.Data2.VoucherNo}", LogLevelEnum.High);
  31. //设备是否停止运行
  32. if (obj.Data3.Status.HasFlag(Entity.Protocol.Station.StatusEunm.Run)) throw new KnownException("设备运行中", LogLevelEnum.Low);
  33. //获取RFID
  34. var barcode = BCRS.GetBCRCode(obj.Entity.Code);
  35. //TODO:上抛WMS任务号与RFID,但不需要跟据上抛结果进行任何处理
  36. WCS_TaskInfo task = null;
  37. var result = SqlSugarHelper.Do(db =>
  38. {
  39. //跟据RFID获取对应的任务
  40. task = db.Default.Queryable<WCS_TaskInfo>().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.High);
  41. if (task.Status != Entity.TaskStatus.AGVExecution) throw new KnownException($"任务:{task.ID}状态不是AGV执行中,请检查异常原因", LogLevelEnum.High);
  42. //获取称重
  43. //task.Weight = obj.Data4.Weight;
  44. task.Status = Entity.TaskStatus.ConveyorExecution;
  45. db.Default.Updateable(task).AddQueue();
  46. //task.AddWCS_TASK_DTL(db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},记录重量:{obj.Data4.Width}.等待分配货位后堆垛机进行取货");
  47. db.Default.SaveQueues();
  48. });
  49. if (task == null || !result) throw new KnownException("数据更新错误", LogLevelEnum.High);
  50. }
  51. public override bool Select(Device dev)
  52. {
  53. return dev.HasFlag(DeviceFlags.巷道口, DeviceFlags.入库, DeviceFlags.扫码);
  54. }
  55. }
  56. }