12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- using ServiceCenter;
- using ServiceCenter.SqlSugars;
- using System.ComponentModel;
- using WCS.Entity;
- using WCS.WorkEngineering.Extensions;
- using WCS.WorkEngineering.Worlds.Logs;
- namespace WCS.WorkEngineering.Worlds
- {
- /// <summary>
- /// 非交互世界
- /// </summary>
- [Description("非交互世界")]
- public class NoInteractionWorld : MainWorld
- {
- /// <summary>
- /// 世界执行周期间隔
- /// 单位:毫秒
- /// </summary>
- protected override int Interval => 300;
- /// <summary>
- /// 更新前执行,重写改方法后请自行添加执行内容
- /// 执行内容:清空日志队列
- /// </summary>
- protected override void BeforeUpdate()
- {
- // 清空日志队列,确保日志队列中只会有当前周期日志
- Logs.Clear();
- #region 处理所有新建出库任务
- SqlSugarHelper.Do(db =>
- {
- //获取所有新建状态的出库任务
- var tasks = db.Default.Queryable<WCS_TaskInfo>().Where(t => t.Status == Entity.TaskStatus.NewBuild).ToList();
- if (tasks.Count > 0)
- {
- Log(new LogInfo { Level = LogLevelEnum.Low, Type = ErrorTypeEnum.Kown, LogUpLoad = LogUpLoadEnum.NotUpLoad, Message = "无新建出库任务" });
- }
- tasks.ForEach(task =>
- {
- //获取堆垛机到目标地址的路径信息
- var path = ServiceHub.deviceInfos.First(v => v.Code == task.Device).Paths.First(v => v.EndCode == task.AddrTo).Path.Split("-");
- //
- task.SrmStation = path[1];
- task.AddrNext = path[2];
- task.Status = Entity.TaskStatus.WaitingToExecute;
- task.AddWCS_TASK_DTL(db, task.Device, $"初始化出库任务信息,放货站台:{task.SrmStation}、放货后下一个地址:{task.AddrNext}");
- db.Default.Updateable(task).AddQueue();
- });
- db.Default.SaveQueues();
- });
- #endregion 处理所有新建出库任务
- }
- }
- }
|