using ServiceCenter.Logs; using ServiceCenter.SqlSugars; using System.ComponentModel; using WCS.Core; using WCS.Entity; using WCS.Entity.Protocol.BCR; using WCS.Entity.Protocol.Station; using WCS.WorkEngineering.Extensions; using WCS.WorkEngineering.WebApi.Controllers; using WCS.WorkEngineering.Worlds; using DeviceFlags = WCS.WorkEngineering.Extensions.DeviceFlags; namespace WCS.WorkEngineering.Systems { /// /// 一楼入库工位处理系统 /// [BelongTo(typeof(MainWorld))] [Description("一楼入库工位处理系统")] public class 一楼入库工位处理系统 : DeviceSystem { protected override bool ParallelDo => true; protected override bool SaveLogsToFile => true; private List BCRS = new List(); public 一楼入库工位处理系统() { BCRS = Device.All.Where(v => v.HasProtocol()).Select(v => new BCR(v, World)).ToList(); } public override void Do(Station obj) { obj.入库站点是否被禁止(); obj.入库站点是否满足执行条件(); WCS_TaskInfo task = null;//处理完成的任务 try { SqlSugarHelper.Do(_db => { var db = _db.Default; //获取RFID var barcode = BCRS.GetBCRCode(obj.Entity.Code); //跟据RFID获取对应的任务 var taskInfo = db.Queryable().First(v => v.BarCode == barcode) ?? throw new KnownException($"未找到RFID:{barcode}对应WCS任务", LogLevelEnum.Mid); if (taskInfo.Status != Entity.TaskStatus.AGVExecution) { if (db.Queryable().SplitTable(v => v.Take(2)).Any(v => v.ParentTaskCode == taskInfo.ID && v.Desc.Contains("等待分配货位后堆垛机进行取货"))) return; else throw new KnownException($"任务:{taskInfo.ID}不是AGV执行状态,请检查异常原因", LogLevelEnum.High); } if (!obj.Data3.Status.HasFlag(StatusEunm.ManualStorage)) //不是手动入库 { //判断AGV任务目标地址是否是当前地址 var agv = db.Queryable().SplitTable(v => v.Take(2)).First(v => v.ID == taskInfo.AgvTaskID) ?? throw new KnownException($"任务{taskInfo.ID}未找到对应AGV任务", LogLevelEnum.Mid); if (taskInfo.AddrNext != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}不是货架上的任务,请检查RFID是否正确", LogLevelEnum.Mid); if (agv.Position != obj.Entity.Code) throw new KnownException($"任务{taskInfo.ID}对应AGV任务目标地址不是当前站台", LogLevelEnum.Mid); } //获取称重 var dev91 = Device.All.Where(v => v.Code == obj.Entity.Code).Select(v => new Device(v, this.World)).FirstOrDefault(); taskInfo.Weight = dev91.Data.Weight; if (taskInfo.Weight < 200) throw new KnownException($"称重结果错误:{taskInfo.Weight}", LogLevelEnum.Mid); //上抛重量 try { WmsApi.WcsUploadInfo(taskInfo.ID, (decimal)taskInfo.Weight, taskInfo.BarCode); } catch (Exception ex) { World.Log(ex.Message, LogLevelEnum.Mid); } taskInfo.Status = Entity.TaskStatus.ConveyorExecution; db.Updateable(taskInfo).ExecuteCommand(); taskInfo.AddWCS_TASK_DTL(_db, obj.Entity.Code, "SRM", $"状态更新为{Entity.TaskStatus.ConveyorExecution},等待分配货位后堆垛机进行取货"); task = taskInfo; }); } catch (Exception ex) { throw new KnownException(ex.Message, LogLevelEnum.High); } obj.Data.TaskNumber = task.ID; obj.Data.VoucherNo++; } public override bool Select(Device dev) { return dev.HasFlag(DeviceFlags.一楼入库口); } } }