| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137 | 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.重绕区{    /// <summary>    ///  组盘缓存生成AGV任务    /// </summary>    [BelongTo(typeof(RewindWorld))]    [Description("组盘缓存生成AGV任务")]    public class 组盘缓存生成AGV任务 : DeviceSystem<Device<IStation520, IStation521, IStation523>>    {        protected override bool ParallelDo => true;        public override void Do(Device<IStation520, IStation521, IStation523> 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<WCS_TaskInfo>().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<WCS_AgvTaskInfo>().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<string> cacheWells = new List<string> { "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<IStation520, IStation521, IStation523>(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<WCS_AgvTaskInfo>().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";        }    }}
 |