|  |  |  | 
|---|
|  |  |  | using iWare_SCADA_BusinessLogical.BLL; | 
|---|
|  |  |  | using iWare_SCADA_BusinessLogical.Utils; | 
|---|
|  |  |  | using iWare_SCADA_Model; | 
|---|
|  |  |  | using iWare_SCADA_Model.TableModel; | 
|---|
|  |  |  | using System; | 
|---|
|  |  |  | using System.Collections.Generic; | 
|---|
|  |  |  | using System.Linq; | 
|---|
|  |  |  | using System.Text; | 
|---|
|  |  |  | using System.Threading; | 
|---|
|  |  |  | using System.Threading.Tasks; | 
|---|
|  |  |  | using System.Web.UI.WebControls; | 
|---|
|  |  |  | //using iWare_SCADA_BusinessLogical.BLL; | 
|---|
|  |  |  | //using iWare_SCADA_BusinessLogical.Utils; | 
|---|
|  |  |  | //using iWare_SCADA_Model; | 
|---|
|  |  |  | //using iWare_SCADA_Model.TableModel; | 
|---|
|  |  |  | //using System; | 
|---|
|  |  |  | //using System.Collections.Generic; | 
|---|
|  |  |  | //using System.Linq; | 
|---|
|  |  |  | //using System.Text; | 
|---|
|  |  |  | //using System.Threading; | 
|---|
|  |  |  | //using System.Threading.Tasks; | 
|---|
|  |  |  | //using System.Web.UI.WebControls; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | namespace iWare_SCADA_BusinessLogical | 
|---|
|  |  |  | { | 
|---|
|  |  |  | /// <summary> | 
|---|
|  |  |  | /// OP35读码完成标记 | 
|---|
|  |  |  | /// </summary> | 
|---|
|  |  |  | public class DataCaptureHandler_OP3501 : DataCaptureHandler | 
|---|
|  |  |  | { | 
|---|
|  |  |  | public static readonly DataCaptureHandler_OP3501 Instance = new DataCaptureHandler_OP3501(); | 
|---|
|  |  |  | //namespace iWare_SCADA_BusinessLogical | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    /// <summary> | 
|---|
|  |  |  | //    /// OP35读码完成标记 | 
|---|
|  |  |  | //    /// </summary> | 
|---|
|  |  |  | //    public class DataCaptureHandler_OP3501 : DataCaptureHandler | 
|---|
|  |  |  | //    { | 
|---|
|  |  |  | //        public static readonly DataCaptureHandler_OP3501 Instance = new DataCaptureHandler_OP3501(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public DataCaptureHandler_OP3501() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        public DataCaptureHandler_OP3501() | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public override string WorkingProcedure | 
|---|
|  |  |  | { | 
|---|
|  |  |  | get { return _dataCaptureConfig.WorkingProcedure; } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        public override string WorkingProcedure | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            get { return _dataCaptureConfig.WorkingProcedure; } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public override string DataCapturePointCode | 
|---|
|  |  |  | { | 
|---|
|  |  |  | get { return _dataCaptureConfig.DataCapturePointCode; } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | public override string DataCapturePointCname | 
|---|
|  |  |  | { | 
|---|
|  |  |  | get { return _dataCaptureConfig.DataCapturePointCname; } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        public override string DataCapturePointCode | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            get { return _dataCaptureConfig.DataCapturePointCode; } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  | //        public override string DataCapturePointCname | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            get { return _dataCaptureConfig.DataCapturePointCname; } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public override void RefreshDataList(List<DataCaptureConfig> dataCaptureConfig) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //        public override void RefreshDataList(List<DataCaptureConfig> dataCaptureConfig) | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | public override void DataCaptureStart() | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (SystemValue.isStartedImitateModel) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var plcService = PLCManger.GetSinglePLCService(_dataCaptureConfig); | 
|---|
|  |  |  | //        public override void DataCaptureStart() | 
|---|
|  |  |  | //        { | 
|---|
|  |  |  | //            if (SystemValue.isStartedImitateModel) | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                var plcService = PLCManger.GetSinglePLCService(_dataCaptureConfig); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | WorkPieceLog wplog = new WorkPieceLog(); | 
|---|
|  |  |  | wplog.Id = Yitter.IdGenerator.YitIdHelper.NextId(); | 
|---|
|  |  |  | wplog.WorkingProcedure = WorkingProcedure; | 
|---|
|  |  |  | wplog.EquipmentID = WorkingProcedure; | 
|---|
|  |  |  | wplog.Remarks = WorkingProcedure; | 
|---|
|  |  |  | wplog.MonitoringPoint = DataCapturePointCode; | 
|---|
|  |  |  | wplog.CreatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | wplog.CreatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | wplog.IsDeleted = false; | 
|---|
|  |  |  | //var valuecol = plcService.ReadValuePoint("2050", "28", 25, typeof(string)); | 
|---|
|  |  |  | //                WorkPieceLog wplog = new WorkPieceLog(); | 
|---|
|  |  |  | //                wplog.Id = Yitter.IdGenerator.YitIdHelper.NextId(); | 
|---|
|  |  |  | //                wplog.WorkingProcedure = WorkingProcedure; | 
|---|
|  |  |  | //                wplog.EquipmentID = WorkingProcedure; | 
|---|
|  |  |  | //                wplog.Remarks = WorkingProcedure; | 
|---|
|  |  |  | //                wplog.MonitoringPoint = DataCapturePointCode; | 
|---|
|  |  |  | //                wplog.CreatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | //                wplog.CreatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | //                wplog.IsDeleted = false; | 
|---|
|  |  |  | //                //var valuecol = plcService.ReadValuePoint("2050", "28", 25, typeof(string)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | wplog.EquipmentID = _dataCaptureConfig.EquipmentID; | 
|---|
|  |  |  | wplog.WorkPieceID = WorkPieceID; | 
|---|
|  |  |  | wplog.UpdatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | wplog.UpdatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | wplog.OnlineTime = DateTimeHelper.GetDateTime();//给上线时间用 | 
|---|
|  |  |  | //                wplog.EquipmentID = _dataCaptureConfig.EquipmentID; | 
|---|
|  |  |  | //                wplog.WorkPieceID = WorkPieceID; | 
|---|
|  |  |  | //                wplog.UpdatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | //                wplog.UpdatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | //                wplog.OnlineTime = DateTimeHelper.GetDateTime();//给上线时间用 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //var valueid = plcService.ReadValuePoint(_dataCaptureConfig.DbNumber, _dataCaptureConfig.Offset, _dataCaptureConfig.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(_dataCaptureConfig.DataCaptureColumnType)); | 
|---|
|  |  |  | //wplog.WorkPieceID = PLCManger.GetWorkPieceIDForPLC(_dataCaptureConfig, plcService); | 
|---|
|  |  |  | if (wplog.WorkPieceID.Length != 22) | 
|---|
|  |  |  | {//获取到的工件号异常 | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | {//获取其他配置的待采集项 | 
|---|
|  |  |  | //                //var valueid = plcService.ReadValuePoint(_dataCaptureConfig.DbNumber, _dataCaptureConfig.Offset, _dataCaptureConfig.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(_dataCaptureConfig.DataCaptureColumnType)); | 
|---|
|  |  |  | //                //wplog.WorkPieceID = PLCManger.GetWorkPieceIDForPLC(_dataCaptureConfig, plcService); | 
|---|
|  |  |  | //                if (wplog.WorkPieceID.Length != 22) | 
|---|
|  |  |  | //                {//获取到的工件号异常 | 
|---|
|  |  |  | //                    return; | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                else | 
|---|
|  |  |  | //                {//获取其他配置的待采集项 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //foreach (var col in colConfig.Where(o => o.DataCapturePointCode == DataCapturePointCode)) | 
|---|
|  |  |  | //{ | 
|---|
|  |  |  | //    var valuecol = plcService.ReadValuePoint(col.DbNumber, col.Offset, col.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(col.DataCaptureColumnType)); | 
|---|
|  |  |  | //    wplog.GetType().GetProperty(col.DataCaptureColumnTabelName).SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  | //                    //foreach (var col in colConfig.Where(o => o.DataCapturePointCode == DataCapturePointCode)) | 
|---|
|  |  |  | //                    //{ | 
|---|
|  |  |  | //                    //    var valuecol = plcService.ReadValuePoint(col.DbNumber, col.Offset, col.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(col.DataCaptureColumnType)); | 
|---|
|  |  |  | //                    //    wplog.GetType().GetProperty(col.DataCaptureColumnTabelName).SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  |  | 
|---|
|  |  |  | //} | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //读取二维码后更新数据库 | 
|---|
|  |  |  | WorkPieceInfoManager.ReadQRcode(wplog, PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), plcService, _dataCaptureConfig.IsFeedback); | 
|---|
|  |  |  | //                    //} | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                //读取二维码后更新数据库 | 
|---|
|  |  |  | //                WorkPieceInfoManager.ReadQRcode(wplog, PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), plcService, _dataCaptureConfig.IsFeedback); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                return; | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if (IsCaptureflag) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var plcService = PLCManger.GetSinglePLCService(_dataCaptureConfig); | 
|---|
|  |  |  | if (plcService == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | SystemValue.lbl_Alert_OP3501 = $"{RandomHelper.GenerateRandomCode(4)} 没有找到{_dataCaptureConfig.WorkingProcedure}的PLC设备"; | 
|---|
|  |  |  | return; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | if (plcService != null && !plcService.IsConnected) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | plcService.Close(); | 
|---|
|  |  |  | plcService.OpenService(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | while (true) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | ThreadStatusMonitor threadStatusMonitor = new ThreadStatusMonitor(); | 
|---|
|  |  |  | threadStatusMonitor.Threadcode = DataCapturePointCode; | 
|---|
|  |  |  | threadStatusMonitor.Threadcname = DataCapturePointCname; | 
|---|
|  |  |  | threadStatusMonitor.Threadendtime = DateTime.Now; | 
|---|
|  |  |  | threadStatusMonitor.Threadlastmodifytime = DateTime.Now; | 
|---|
|  |  |  | threadStatusMonitor.Threadstatue = 0; | 
|---|
|  |  |  | threadStatusMonitor.ThreadId = Thread.CurrentThread.ManagedThreadId.ToString(); | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | if (plcService == null || !plcService.IsConnected) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | threadStatusMonitor.Remarks= $" {RandomHelper.GenerateRandomCode(4)} {_dataCaptureConfig.WorkingProcedure} PLC连接已断开,正在尝试打开!"; | 
|---|
|  |  |  | SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} {_dataCaptureConfig.WorkingProcedure} PLC连接已断开,正在尝试打开!"; | 
|---|
|  |  |  | plcService.Close(); | 
|---|
|  |  |  | plcService.OpenService(); | 
|---|
|  |  |  | Thread.Sleep(100); | 
|---|
|  |  |  | continue; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | object value = plcService.ReadValuePoint(_dataCaptureConfig.DbNumber, _dataCaptureConfig.Offset, PLCManger.GetTypeForString(_dataCaptureConfig.DataCaptureColumnType)); | 
|---|
|  |  |  | if (SystemValue.value_OP3501.Equals("FALSE") && value.ToString().ToUpper().Equals("TRUE")) | 
|---|
|  |  |  | {//当上一标记位0,当前获取标记为1时, | 
|---|
|  |  |  | //触发操作,  并给静态变量赋值为1 | 
|---|
|  |  |  | //业务代码 | 
|---|
|  |  |  | WorkPieceLog wplog = new WorkPieceLog(); | 
|---|
|  |  |  | wplog.Id = Yitter.IdGenerator.YitIdHelper.NextId(); | 
|---|
|  |  |  | wplog.WorkingProcedure = WorkingProcedure; | 
|---|
|  |  |  | wplog.EquipmentID = WorkingProcedure; | 
|---|
|  |  |  | wplog.Remarks = WorkingProcedure; | 
|---|
|  |  |  | wplog.MonitoringPoint = DataCapturePointCode; | 
|---|
|  |  |  | wplog.CreatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | wplog.CreatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | wplog.UpdatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | wplog.UpdatedUserName = Environment.MachineName+"自动"; | 
|---|
|  |  |  | wplog.OnlineTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | wplog.IsDeleted = false; | 
|---|
|  |  |  | //            if (IsCaptureflag) | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                var plcService = PLCManger.GetSinglePLCService(_dataCaptureConfig); | 
|---|
|  |  |  | //                if (plcService == null) | 
|---|
|  |  |  | //                { | 
|---|
|  |  |  | //                    SystemValue.lbl_Alert_OP3501 = $"{RandomHelper.GenerateRandomCode(4)} 没有找到{_dataCaptureConfig.WorkingProcedure}的PLC设备"; | 
|---|
|  |  |  | //                    return; | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                if (plcService != null && !plcService.IsConnected) | 
|---|
|  |  |  | //                { | 
|---|
|  |  |  | //                    plcService.Close(); | 
|---|
|  |  |  | //                    plcService.OpenService(); | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //                while (true) | 
|---|
|  |  |  | //                { | 
|---|
|  |  |  | //                    ThreadStatusMonitor threadStatusMonitor = new ThreadStatusMonitor(); | 
|---|
|  |  |  | //                    threadStatusMonitor.Threadcode = DataCapturePointCode; | 
|---|
|  |  |  | //                    threadStatusMonitor.Threadcname = DataCapturePointCname; | 
|---|
|  |  |  | //                    threadStatusMonitor.Threadendtime = DateTime.Now; | 
|---|
|  |  |  | //                    threadStatusMonitor.Threadlastmodifytime = DateTime.Now; | 
|---|
|  |  |  | //                    threadStatusMonitor.Threadstatue = 0; | 
|---|
|  |  |  | //                    threadStatusMonitor.ThreadId = Thread.CurrentThread.ManagedThreadId.ToString(); | 
|---|
|  |  |  | //                    try | 
|---|
|  |  |  | //                    { | 
|---|
|  |  |  | //                        if (plcService == null || !plcService.IsConnected) | 
|---|
|  |  |  | //                        { | 
|---|
|  |  |  | //                            threadStatusMonitor.Remarks= $" {RandomHelper.GenerateRandomCode(4)} {_dataCaptureConfig.WorkingProcedure} PLC连接已断开,正在尝试打开!"; | 
|---|
|  |  |  | //                            SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} {_dataCaptureConfig.WorkingProcedure} PLC连接已断开,正在尝试打开!"; | 
|---|
|  |  |  | //                            plcService.Close(); | 
|---|
|  |  |  | //                            plcService.OpenService(); | 
|---|
|  |  |  | //                            Thread.Sleep(100); | 
|---|
|  |  |  | //                            continue; | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                        else | 
|---|
|  |  |  | //                        { | 
|---|
|  |  |  | //                            object value = plcService.ReadValuePoint(_dataCaptureConfig.DbNumber, _dataCaptureConfig.Offset, PLCManger.GetTypeForString(_dataCaptureConfig.DataCaptureColumnType)); | 
|---|
|  |  |  | //                            if (SystemValue.value_OP3501.Equals("FALSE") && value.ToString().ToUpper().Equals("TRUE")) | 
|---|
|  |  |  | //                            {//当上一标记位0,当前获取标记为1时, | 
|---|
|  |  |  | //                             //触发操作,  并给静态变量赋值为1 | 
|---|
|  |  |  | //                             //业务代码 | 
|---|
|  |  |  | //                                WorkPieceLog wplog = new WorkPieceLog(); | 
|---|
|  |  |  | //                                wplog.Id = Yitter.IdGenerator.YitIdHelper.NextId(); | 
|---|
|  |  |  | //                                wplog.WorkingProcedure = WorkingProcedure; | 
|---|
|  |  |  | //                                wplog.EquipmentID = WorkingProcedure; | 
|---|
|  |  |  | //                                wplog.Remarks = WorkingProcedure; | 
|---|
|  |  |  | //                                wplog.MonitoringPoint = DataCapturePointCode; | 
|---|
|  |  |  | //                                wplog.CreatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | //                                wplog.CreatedUserName = DataCapturePointCode; | 
|---|
|  |  |  | //                                wplog.UpdatedTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | //                                wplog.UpdatedUserName = Environment.MachineName+"自动"; | 
|---|
|  |  |  | //                                wplog.OnlineTime = DateTimeHelper.GetDateTime(); | 
|---|
|  |  |  | //                                wplog.IsDeleted = false; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | foreach (var col in colConfig.Where(o => o.DataCapturePointCode == DataCapturePointCode)) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | try | 
|---|
|  |  |  | { | 
|---|
|  |  |  | var valuecol = plcService.ReadValuePoint(col.DbNumber, col.Offset, col.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(col.DataCaptureColumnType)); | 
|---|
|  |  |  | //wplog.GetType().GetProperty(col.DataCaptureColumnTabelName).SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  | var set = wplog.GetType().GetProperty(col.DataCaptureColumnTabelName); | 
|---|
|  |  |  | if (set == null) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $" {DataCapturePointCode}工序监控上线完成标记 读取工件码动态由于字段名没找到,赋值【{WorkingProcedure ?? "空字符串"}】失败{wplog.Id}"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | set.SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception setex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $" {DataCapturePointCode}工序监控上线完成标记 读取工件码动态赋值【{WorkingProcedure ?? "空字符串"}】异常{wplog.Id}", setex); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //读取二维码后更新数据库 | 
|---|
|  |  |  | WorkPieceInfoManager.ReadQRcode(wplog, PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), plcService, _dataCaptureConfig.IsFeedback); | 
|---|
|  |  |  | //                                foreach (var col in colConfig.Where(o => o.DataCapturePointCode == DataCapturePointCode)) | 
|---|
|  |  |  | //                                { | 
|---|
|  |  |  | //                                    try | 
|---|
|  |  |  | //                                    { | 
|---|
|  |  |  | //                                        var valuecol = plcService.ReadValuePoint(col.DbNumber, col.Offset, col.DataCaptureColumnLength.Value, PLCManger.GetTypeForString(col.DataCaptureColumnType)); | 
|---|
|  |  |  | //                                        //wplog.GetType().GetProperty(col.DataCaptureColumnTabelName).SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  | //                                        var set = wplog.GetType().GetProperty(col.DataCaptureColumnTabelName); | 
|---|
|  |  |  | //                                        if (set == null) | 
|---|
|  |  |  | //                                        { | 
|---|
|  |  |  | //                                            Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $" {DataCapturePointCode}工序监控上线完成标记 读取工件码动态由于字段名没找到,赋值【{WorkingProcedure ?? "空字符串"}】失败{wplog.Id}"); | 
|---|
|  |  |  | //                                        } | 
|---|
|  |  |  | //                                        set.SetValue(wplog, valuecol);//给动态字段赋值 | 
|---|
|  |  |  | //                                    } | 
|---|
|  |  |  | //                                    catch (Exception setex) | 
|---|
|  |  |  | //                                    { | 
|---|
|  |  |  | //                                        Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $" {DataCapturePointCode}工序监控上线完成标记 读取工件码动态赋值【{WorkingProcedure ?? "空字符串"}】异常{wplog.Id}", setex); | 
|---|
|  |  |  | //                                    } | 
|---|
|  |  |  | //                                } | 
|---|
|  |  |  | //                                //读取二维码后更新数据库 | 
|---|
|  |  |  | //                                WorkPieceInfoManager.ReadQRcode(wplog, PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), plcService, _dataCaptureConfig.IsFeedback); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | threadStatusMonitor.Threadstatue = 1; | 
|---|
|  |  |  | //                                threadStatusMonitor.Threadstatue = 1; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SystemValue.value_OP3501 = value.ToString(); | 
|---|
|  |  |  | //                            } | 
|---|
|  |  |  | //                            SystemValue.value_OP3501 = value.ToString(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | SystemValue.lbl_Alert_OP3501 = $"abcdefg:{RandomHelper.GenerateRandomCode(4)}"; | 
|---|
|  |  |  | if (!_dataCaptureConfig.DataCaptureFrequency.HasValue || _dataCaptureConfig.DataCaptureFrequency < 10) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | threadStatusMonitor.ThreadFrequency = 5000; | 
|---|
|  |  |  | Thread.Sleep(5000); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | threadStatusMonitor.ThreadFrequency = _dataCaptureConfig.DataCaptureFrequency.Value; | 
|---|
|  |  |  | Thread.Sleep(_dataCaptureConfig.DataCaptureFrequency.Value); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                        SystemValue.lbl_Alert_OP3501 = $"abcdefg:{RandomHelper.GenerateRandomCode(4)}"; | 
|---|
|  |  |  | //                        if (!_dataCaptureConfig.DataCaptureFrequency.HasValue || _dataCaptureConfig.DataCaptureFrequency < 10) | 
|---|
|  |  |  | //                        { | 
|---|
|  |  |  | //                            threadStatusMonitor.ThreadFrequency = 5000; | 
|---|
|  |  |  | //                            Thread.Sleep(5000); | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  | //                        else | 
|---|
|  |  |  | //                        { | 
|---|
|  |  |  | //                            threadStatusMonitor.ThreadFrequency = _dataCaptureConfig.DataCaptureFrequency.Value; | 
|---|
|  |  |  | //                            Thread.Sleep(_dataCaptureConfig.DataCaptureFrequency.Value); | 
|---|
|  |  |  | //                        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | catch (Exception ex) | 
|---|
|  |  |  | { | 
|---|
|  |  |  | SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} 读取{DataCapturePointCode}工序监控上线标记 出现异常,请查看日志!"; | 
|---|
|  |  |  | Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $"读取 {DataCapturePointCode}工序监控上线标记数据时异常:", ex); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | finally | 
|---|
|  |  |  | { | 
|---|
|  |  |  | WorkPieceInfoManager.ThreadMonitor(threadStatusMonitor); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | else | 
|---|
|  |  |  | { | 
|---|
|  |  |  | SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} {DataCapturePointCode}工序监控上线标记 不做校验,请确认配置信息!"; | 
|---|
|  |  |  | Log4NetHelper.WriteInfoLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $"读{DataCapturePointCode}工序监控上线标记 不做校验,请确认是否配置异常"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                    catch (Exception ex) | 
|---|
|  |  |  | //                    { | 
|---|
|  |  |  | //                        SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} 读取{DataCapturePointCode}工序监控上线标记 出现异常,请查看日志!"; | 
|---|
|  |  |  | //                        Log4NetHelper.WriteErrorLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $"读取 {DataCapturePointCode}工序监控上线标记数据时异常:", ex); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                    finally | 
|---|
|  |  |  | //                    { | 
|---|
|  |  |  | //                        WorkPieceInfoManager.ThreadMonitor(threadStatusMonitor); | 
|---|
|  |  |  | //                    } | 
|---|
|  |  |  | //                } | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //            else | 
|---|
|  |  |  | //            { | 
|---|
|  |  |  | //                SystemValue.lbl_Alert_OP3501 = $" {RandomHelper.GenerateRandomCode(4)} {DataCapturePointCode}工序监控上线标记 不做校验,请确认配置信息!"; | 
|---|
|  |  |  | //                Log4NetHelper.WriteInfoLog(PLCManger.GetLogTypeForWorkingProcedure(WorkingProcedure), $"读{DataCapturePointCode}工序监控上线标记 不做校验,请确认是否配置异常"); | 
|---|
|  |  |  | //            } | 
|---|
|  |  |  | //        } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | //    } | 
|---|
|  |  |  | //} | 
|---|