| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222 | using NetTaste;using Newtonsoft.Json;using NPOI.SS.Formula.PTG;using Org.BouncyCastle.Bcpg;using ServiceCenter.SqlSugars;using SqlSugar;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.Protocol.Robot;using WCS.Entity.Protocol.Robot;using WCS.Entity.Protocol.Station;using WCS.WorkEngineering.Extensions;using WCS.WorkEngineering.WebApi.Models.WCS.Request;using WCS.WorkEngineering.Worlds;using static ICSharpCode.SharpZipLib.Zip.ExtendedUnixData;namespace WCS.WorkEngineering.Systems{    [BelongTo(typeof(RobotWorld))]    [Description("机器人抓取")]    public class 机器人抓取 : DeviceSystem<Device<IRobot520, IRobot521, IRobot522>>    {        protected override bool ParallelDo => false;        private Device<IStation521, IRobot531>[] PalletStations;        public 机器人抓取()        {            var arr = Device.All.Where(v => v.HasProtocol<IStation521>() && v.HasFlag("装箱码垛") && v.HasFlag("位置", "码垛")).ToArray();            PalletStations = arr.Select(v => new Device<IStation521, IRobot531>(v, this.World)).ToArray();        }        public override void Do(Device<IRobot520, IRobot521, IRobot522> obj)        {            if (obj.Data.VoucherNo != obj.Data2.VoucherNo)            {                MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "凭证号不一样,不允许做新的交互", Time = DateTime.Now }));                return;            }            if (obj.Data2.Mode != RobotMode.自动)            {                MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "不是自动模式", Time = DateTime.Now }));                return;            }            if (obj.Data2.Alarm != 0)            {                MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "有报警,请先解决报警", Time = DateTime.Now }));                World.Log($"{obj.Data3.Alarm}");                return;            }            World.Log($"码垛任务下发{obj.Entity.Code}交互开始时间:一个周期" + DateTime.Now.ToString("yyyyMMddHHmmss"));            if (obj.Data2.Rqst == RobotRqst.抓取完成)            {                var tasks = new int[] { obj.Data2.Task1, obj.Data2.Task2, obj.Data2.Task3 }.Take(obj.Data2.TaskQty).ToArray();                if (tasks.Any(v => v == 0) || tasks.Length == 0)                {                    MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "抓取完成时任务号有误", Time = DateTime.Now }));                    throw new Exception("抓取完成时任务号有误");                }                var res = WMS.抓取完成(tasks, obj.Data2.AddrTo.ToString());                if (!res.Success)                {                    MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "码垛绑定失败," + res.ResMsg, Time = DateTime.Now }));                    throw new Exception("码垛绑定失败," + res.ResMsg);                }                SqlSugarHelper.Do(db =>                {                    var arr = db.Default.Queryable<WCS_TaskInfo>().Where(v => tasks.Contains(v.ID)).ToArray();                    foreach (var task in arr)                    {                        if (task.Status != Entity.TaskStatus.码垛抓取中)                        {                            MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{obj.Entity.Code},任务{task.ID}状态有误", Time = DateTime.Now }));                            throw new Exception($"任务{task.ID}状态有误");                        }                        task.Status = Entity.TaskStatus.码垛抓取完成;                        task.EditTime = DateTime.Now;                        db.Default.Updateable(task).ExecuteCommand();                        task.AddWCS_TASK_DTL(db.Default, obj.Data2.AddrTo.ToString(), "码垛抓取完成");                    }                    if (obj.Data.VoucherNo == -1)                    {                        obj.Data.Cmd = RobotCmd.抓取完成确认;                        obj.Data.VoucherNo = 1;                    }                    else                    {                        obj.Data.Cmd = RobotCmd.抓取完成确认;                        obj.Data.VoucherNo++;                    }                });                return;            }            if (obj.Data2.Status != RobotRunStatus.空闲)                return;            var temp = PalletStations.Where(v => v.Entity.HasFlag("Robot", obj.Entity.Code))                .Where(v => v.Data.TaskNumber > 0 && v.Data.TaskNumber == v.Data2.PalletID).ToArray();            if (temp.Length == 0)            {                MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = obj.Entity.Code + "码垛位状态未就绪", Time = DateTime.Now }));                World.Log("码垛位状态未就绪");                return;            }            var temp2 = temp.Select(v => new { PalletStation = v, QtyLeft = v.Data2.MaxQty - v.Data2.Qty, PickStation = Device.All.Where(d => d.HasFlag("装箱码垛") && d.HasFlag("位置", "抓取") && d.HasFlag("码垛工位", v.Entity.Code)).First() }).ToArray();            var temp3 = temp2.Select(v => new { v.PalletStation, v.QtyLeft, v.PickStation, Arr = Device.All.Where(d => d.HasFlag("装箱码垛") && d.HasFlag("Parent", v.PickStation.Code)).Select(d => d.Protocol<IStation521>(this.World)).ToArray() }).ToArray();            var stArr = temp3.Select(v => new { v.PalletStation, v.QtyLeft, v.PickStation, Tasks = v.Arr.Select(d => d.TaskNumber).Where(d => d > 10000).ToArray() })                .Where(v => v.Tasks.Length > 0).ToArray();            if (stArr.Length == 0)            {                World.Log("抓取位空");                return;            }            SqlSugarHelper.Do(db =>            {                foreach (var item in stArr.OrderBy(v => v.QtyLeft))                {                    var stCode = item.PalletStation.Entity.Code;                    if (!item.PickStation.Protocol<IStation523>(this.World).Status.HasFlag(StationStatus.自动))                    {                        MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{item.PickStation.Code}不在自动模式", Time = DateTime.Now }));                        World.Log($"{item.PickStation.Code}不在自动模式", ServiceCenter.Logs.LogLevelEnum.High);                        continue;                    }                    try                    {                        var flag = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.AddrTo == item.PalletStation.Entity.Code && v.Status == Entity.TaskStatus.码垛抓取中).Any();                        if (flag)                        {                            World.Log($"{stCode}有正在抓取中的任务");                            continue;                        }                        var p = db.Default.Queryable<Palletizing>().Where(v => v.TaskNum == item.PalletStation.Data.TaskNumber).Where(v => v.PalletizState == 0).First();                        if (p == null)                        {                            World.Log($"{stCode}托盘无码垛数据", ServiceCenter.Logs.LogLevelEnum.High);                            MainWorld.Redis.Set($"Sx:WCSErrorInfo:{obj.Entity.Code}", JsonConvert.SerializeObject(new RedisError() { Equip = obj.Entity.Code, Con = $"{stCode}托盘无码垛数据", Time = DateTime.Now }));                            continue;                        }                        if (item.Tasks.Distinct().Count() < 3)                        {                            if (p.Count >= p.Finish)                                continue;                            var qty = db.Default.Queryable<WCS_TaskInfo>().Where(v => v.Type == TaskType.OutDepot && v.BusType == "装箱码垛")                            .Where(v => v.Status >= Entity.TaskStatus.码垛缓存放行 && v.Status <= Entity.TaskStatus.码垛缓存扫码).Count();                            if (qty > item.Tasks.Length)                            {                                World.Log($"{stCode}有额外货物已缓存放行");                            }                        }                        var rc = db.Default.Updateable<WCS_TaskInfo>()                           .SetColumns(v => new WCS_TaskInfo { Status = Entity.TaskStatus.码垛抓取中, EditTime = SqlFunc.GetDate() })                           .Where(v => item.Tasks.Contains(v.ID))                           .Where(v => v.Status == Entity.TaskStatus.码垛抓取扫码)                           .ExecuteCommand();                        if (rc != item.Tasks.Length)                        {                            if (db.Default.Updateable<WCS_TaskInfo>().SetColumns(v => new WCS_TaskInfo { Status = Entity.TaskStatus.码垛抓取中, EditTime = SqlFunc.GetDate() })                                                                     .Where(v => item.Tasks.Contains(v.ID)).ExecuteCommand() > 0)                            {                                World.Log($"{stCode}触发任务状态重复修改机制", ServiceCenter.Logs.LogLevelEnum.High);                            }                            else                            {                                World.Log($"{stCode}修改任务状态失败,", ServiceCenter.Logs.LogLevelEnum.High);                                continue;                            }                        }                        obj.Data.GoodsType = (short)p.GoodsType;                        obj.Data.AddrFrom = short.Parse(item.PickStation.Code);                        obj.Data.AddrTo = short.Parse(item.PalletStation.Entity.Code);                        obj.Data.TaskQty = (short)item.Tasks.Length;                        obj.Data.Task1 = item.Tasks[0];                        if (item.Tasks.Length > 1)                            obj.Data.Task2 = item.Tasks[1];                        else                            obj.Data.Task2 = 0;                        if (item.Tasks.Length > 2)                            obj.Data.Task3 = item.Tasks[2];                        else                            obj.Data.Task3 = 0;                        if (obj.Data.VoucherNo == -1)                        {                            obj.Data.Cmd = RobotCmd.抓取;                            obj.Data.VoucherNo = 1;                        }                        else                        {                            obj.Data.Cmd = RobotCmd.抓取;                            obj.Data.VoucherNo++;                        }                        break;                    }                    catch (Exception ex)                    {                        World.Log($"{stCode}异常:{ex.Message}");                    }                }            });            World.Log($"码垛任务下发{obj.Entity.Code}交互结束时间:一个周期" + DateTime.Now.ToString("yyyyMMddHHmmss"));        }        public override bool Select(Device dev)        {            return dev.Code is "Robot1" or "Robot2";        }    }}
 |