quanzhou
2026-01-19 57e86e9be5d5fa6f854761ca915a64ee67869724
src/Bro.M141_AOI1.Process/AOI1Process.cs
@@ -329,10 +329,10 @@
                        {
                            try
                            {
                                var obj = JsonConvert.DeserializeObject<AutoLineMacQueueBak>(zwordstr);
                                ConfigAOI1.zwoid = obj.zwoid;
                                var obj = JsonConvert.DeserializeObject<AutoLineMacQueueBak>(zwordstr);
                                if (!string.IsNullOrEmpty(obj.zwoid) && obj.zstatus == "200")
                                {
                                    ConfigAOI1.zwoid = obj.zwoid;
                                    Plc1.WriteSingleAddress(1524, 1, out _);
                                    Plc1.WriteSingleAddress(1514, 1, out _);
                                    LogAsync(DateTime.Now, EnumHelper.LogLevel.Information, $"RabbitMQ zwoid获取成功 {obj.zstatus} {obj.zwoid} ");
@@ -747,8 +747,8 @@
        {
            ResponseMessage msg = new ResponseMessage();
            var plcnum11 = Plc3.Read(1542, 1, out _);
            var plcnum12 = Plc3.Read(1544, 1, out _);
            var plcnum11 = Plc1.Read(1542, 1, out _);
            var plcnum12 = Plc1.Read(1544, 1, out _);
            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"PLC信息记录保存触发 获取PLC序号{plcnum11[0]}和{plcnum12[0]}");
@@ -784,7 +784,7 @@
                    else
                    {
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Exception, $"产品{pro.PID}数据上传MES失败  {tems}");
                        result = "obj.zerrmsg";
                        result = string.Empty;
                        if (obj.zerrmsg.Contains("重复数据"))
                        {
                            return true;
@@ -877,6 +877,11 @@
           
        }
        /// <summary>
        /// 产品零盘上传启动标识
        /// </summary>
        private bool isStartclear =false;
        [ProcessMethod("", "MEStogetcode", "MES上传整批数据并获取条码", InvokeType.TestInvoke)]
        public ResponseMessage MEStogetcode(IOperationConfig config, IDevice invokeDevice, IDevice sourceDevice)
        {
@@ -894,14 +899,8 @@
            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品信息上传mes触发,获取PLC序号{plcnum[0]}和{plcnum1[0]}");
            string saveTary_ID=string.Empty;
            if (!Issuccess && !Issuccess1)
            {
                Plc3.WriteSingleAddress(2120, 2, out _);
                return msg;
            }
            string saveTary_ID= string.Empty;
            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品信息上传MES触发,产品信息数量为:{M141Config.Productioncode.Count}");
            if (M141Config.Productioncode.Count == 50)
@@ -917,7 +916,26 @@
                    newp.Result = "OK";
                    newp.SN = M141Config.Productioncode[0].SN;
                    string tary_ID = string.Empty;
                    bool isok = UptoMES(newp, "N", out tary_ID);
                    bool isok = true;
                    if (M141Config.Productioncode.Count==1)
                    {
                        if (isStartclear)
                        {
                            isok = UptoMES(newp, "Y", out tary_ID);
                            isStartclear = false;
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品{newp.PID}启动零盘尾数上传");
                        }
                        else
                        {
                            isok = UptoMES(newp, "N", out tary_ID);
                        }
                    }
                    else
                    {
                        isok = UptoMES(newp, "N", out tary_ID);
                    }
                    if (!isok)
                    {
                        Plc3.WriteSingleAddress(2120, 2, out _);
@@ -925,13 +943,22 @@
                    }
                    if (M141Config.Isprint && !string.IsNullOrEmpty(tary_ID))
                    {
                        saveTary_ID = tary_ID;
                        StartPrint(tary_ID, "Honeywell PX240S(300 dpi)");
                        M141Config.MES_codes.Add(new MES_code
                        if (M141Config.Productioncode.Count == 1)
                        {
                            Printers_code = tary_ID
                        });
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                            saveTary_ID = tary_ID;
                            StartPrint(tary_ID, "Honeywell PX240S (300 dpi)");
                            M141Config.MES_codes.Add(new MES_code
                            {
                                Printers_code = tary_ID
                            });
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                        }
                        else
                        {
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Error, $"条码:{tary_ID}不是在最后一件产品获取,启动零盘清除复位产品上传动作");
                            isStartclear = true;
                        }
                    }                
                    M141Config.Productioncode.RemoveAt(0);
                }
@@ -939,7 +966,7 @@
            }
            else if (M141Config.Productioncode.Count > 50)
            {
                //中途有产品被取走
                //中途有产品被取走导致条码大于实际数量
                for (int i = 0; i < 50; i++)
                {
                    ProductModel newp = new ProductModel();
@@ -951,7 +978,25 @@
                    newp.Result = "OK";
                    newp.SN = M141Config.Productioncode[count - 1].SN;
                    string tary_ID = string.Empty;
                    bool isok = UptoMES(newp, "N", out tary_ID);
                    bool isok = true;
                    if (i==49)
                    {
                        if (isStartclear)
                        {
                            isok = UptoMES(newp, "Y", out tary_ID);
                            isStartclear = false;
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品{newp.PID}启动零盘尾数上传");
                        }
                        else
                        {
                            isok = UptoMES(newp, "N", out tary_ID);
                        }
                    }
                    else
                    {
                        isok = UptoMES(newp, "N", out tary_ID);
                    }
                    if (!isok)
                    {
                        Plc3.WriteSingleAddress(2120, 2, out _);
@@ -960,13 +1005,22 @@
                    }
                    if (M141Config.Isprint && !string.IsNullOrEmpty(tary_ID))
                    {
                        saveTary_ID = tary_ID;
                        StartPrint(tary_ID, "Honeywell PX240S(300 dpi)");
                        M141Config.MES_codes.Add(new MES_code
                        if (i == 49)
                        {
                            Printers_code = tary_ID
                        });
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                            saveTary_ID = tary_ID;
                            StartPrint(tary_ID, "Honeywell PX240S (300 dpi)");
                            M141Config.MES_codes.Add(new MES_code
                            {
                                Printers_code = tary_ID
                            });
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                        }
                        else
                        {
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Error, $"条码:{tary_ID}不是在最后一件产品获取,启动零盘清除复位产品上传动作");
                            isStartclear = true;
                        }
                    }
                    M141Config.Productioncode.RemoveAt(count - 1);
                }
@@ -974,7 +1028,7 @@
            }
            else if (M141Config.Productioncode.Count > 0 && M141Config.Productioncode.Count < 50)
            {
                //产品缺少需要额外的条码补救
                //产品缺少需要清除零盘
                while (M141Config.Productioncode.Count > 0)
                {
                    ProductModel newp = new ProductModel();
@@ -990,7 +1044,7 @@
                    if (M141Config.Productioncode.Count==1)
                    {
                        isok = UptoMES(newp, "Y", out tary_ID);
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品{newp.PID}触发零数尾盘");
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"产品{newp.PID}启动零盘尾数上传");
                    }
                    else
                    {
@@ -1003,13 +1057,21 @@
                    }
                    if (M141Config.Isprint && !string.IsNullOrEmpty(tary_ID))
                    {
                        saveTary_ID = tary_ID;
                        StartPrint(tary_ID, "Honeywell PX240S(300 dpi)");
                        M141Config.MES_codes.Add(new MES_code
                        if (M141Config.Productioncode.Count == 1)
                        {
                            Printers_code = tary_ID
                        });
                        LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                            saveTary_ID = tary_ID;
                            StartPrint(tary_ID, "Honeywell PX240S (300 dpi)");
                            M141Config.MES_codes.Add(new MES_code
                            {
                                Printers_code = tary_ID
                            });
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Assist, $"条码:{tary_ID}已触发S6打印并且保存");
                        }
                        else
                        {
                            LogAsync(DateTime.Now, EnumHelper.LogLevel.Error, $"条码:{tary_ID}不是在最后一件产品获取,启动零盘清除复位产品上传动作");
                            isStartclear = true;
                        }
                    }
                    M141Config.Productioncode.RemoveAt(0);
                }
@@ -1019,20 +1081,11 @@
            {
                if (M141Config.Isprint && !string.IsNullOrEmpty(saveTary_ID))
                {
                    StartPrint(saveTary_ID, "Honeywell PX240S(300 dpi)");
                    StartPrint(saveTary_ID, "Honeywell PX240S (300 dpi)");
                }      
            }
            if (Issuccess && Issuccess1)
            {
                Plc3.WriteSingleAddress(2120, 1, out _);
                return msg;
            }
            else
            {
                Plc3.WriteSingleAddress(2120, 2, out _);
                return msg;
            }
               Plc3.WriteSingleAddress(2120, 1, out _);
               return msg;
        }
        [ProcessMethod("", "MESup1", "MES上传进料口空篮", InvokeType.TestInvoke)]