using Microsoft.OpenApi.Extensions; using ServiceCenter.Extensions; using ServiceCenter.Logs; using ServiceCenter.SqlSugars; using System; using System.Collections.Generic; using System.ComponentModel; using System.Linq; using System.Text; using System.Threading.Tasks; using WCS.Core; using WCS.Entity; using WCS.Entity.Protocol.Station; using WCS.WorkEngineering.Extensions; using WCS.WorkEngineering.WebApi.Controllers; using WCS.WorkEngineering.WebApi.Models.WMS.Response; using WCS.WorkEngineering.Worlds; using TaskStatus = WCS.Entity.TaskStatus; namespace WCS.WorkEngineering.Systems.重绕区 { /// /// 组盘缓存生成AGV任务 /// [BelongTo(typeof(RewindWorld))] [Description("组盘缓存生成AGV任务")] public class 组盘缓存生成AGV任务 : DeviceSystem> { protected override bool ParallelDo => true; public override void Do(Device obj) { if (!obj.Data3.Status.HasFlag(StationStatus.Auto)) { World.Log($"设备处于{obj.Data3.Status.GetDisplayName()}状态"); return; } if (!obj.Data3.Status.HasFlag(StationStatus.PH_Status)) { World.Log($"设备无光电"); return; } SqlSugarHelper.Do(_db => { var db = _db.Default; var task = db.Queryable().ReadPastUpdLock().Single(x => x.Status == TaskStatus.ConveyorExecution && x.ID == obj.Data2.TaskNumber); if (task == null) { World.Log($"未找到对应任务[{obj.Data2.TaskNumber}],请检查该任务状态与更新状态是否均为输送机执行中", LogLevelEnum.High); return; } var agvId = DateTime.Now.GetFormat(GetFormatterEnum.only) + task.ID; //开始创建AGV任务 var agvTask = db.Queryable().RowLock().SplitTable(x => x.Take(2)).Single(x => x.TaskId == task.ID && x.TaskType == AGVTaskType.EnterDepot); if (agvTask == null) { db.InsertableRowLock(new WCS_AgvTaskInfo() { ID = _db.GetAgvTaskId(), TaskType = AGVTaskType.EnterDepot, Status = AGVTaskStatus.NewBuild, TaskId = task.ID, Position = obj.Entity.Code, Station = task.SrmStation, WorkShop = 111, AddWho = "WCS", AddTime = DateTime.Now, AgvID = agvId }).SplitTable().ExecuteCommand(); World.Log($"{task.ID}未找到对应的AGV任务"); return; } if (agvTask.Status != AGVTaskStatus.NewBuild) { World.Log($"AGV任务{agvTask.ID}状态不是新建", LogLevelEnum.High); return; } //分配缓存货位 暂时先根据光电判断 List cacheWells = new List { "9201", "9202", "9203", "9204", "9205", "9206", "9207", "9208", "9209","9210","9211","9212", "9213","9214","9215",/*"9216","9217","9218","9219","9220","9221","9222","9223","9224"*/}; var devs = Device.All.Where(x => cacheWells.Contains(x.Code)).Select(x => new Device(x, World)); if (!devs.Any()) return; string sta = ""; if (!devs.Any(v => !v.Data3.Status.HasFlag(StationStatus.PH_Status))) return; foreach (var dev in devs) { if (!dev.Data3.Status.HasFlag(StationStatus.PH_Status) && !db.Queryable().RowLock().SplitTable(x => x.Take(2)).Any(x => x.Station == dev.Entity.Code && x.TaskType == AGVTaskType.EnterDepot && x.Status < AGVTaskStatus.MissionCompleted)) { var res = WmsApi.GetFlatLocalIn(obj.Data2.TaskNumber,"T1",dev.Entity.Code,1); if (res.ResCode == ResponseStatusCodeEnum.Sucess && res.ResData.CellNo == dev.Entity.Code) { sta = dev.Entity.Code; } else if (res.ResCode == ResponseStatusCodeEnum.Sucess) { sta = res.ResData.CellNo; World.Log($"{dev.Entity.Code}分配货位{res.ResData.CellNo}"); } else { continue; } break; //sta = dev.Entity.Code; //break; } } agvId = agvTask.AgvID; if (sta == "") return; agvTask.Status = AGVTaskStatus.Confirm; agvTask.AgvStatus = AGVTaskStatus.Confirm; agvTask.Station = sta; db.UpdateableRowLock(agvTask).UpdateColumns(x => new { x.AgvID, x.Status, x.AgvStatus, x.Station }).SplitTable(x => x.Take(2)).ExecuteCommand(); task.Status = TaskStatus.AGVExecution; task.AgvTaskID = agvTask.ID; task.EditTime = DateTime.Now; task.EditWho = "WCS"; task.AddrFrom = obj.Entity.Code; task.AddrTo = agvTask.Station; db.Updateable(task).UpdateColumns(x => new { x.Status, x.AgvTaskID, x.EditTime, x.EditWho,x.AddrFrom, x.AddrTo }).ExecuteCommand(); task.AddWCS_TASK_DTL(db, obj.Entity.Code, "AGV", $"任务下发至AGV{agvId},目标缓存货位{agvTask.Station}"); AgvApi.组盘入库(obj.Entity.Code, agvTask.Station, agvId); }); } public override bool Select(Device dev) { return dev.Code is "9126"; } } }