using Admin.NET.Application; using iWareCC.Common.Helper; using iWareCC.DeviceThreadFactory; using iWareCC.Forms; using iWareCC.RgvService; using iWareCC.SrmService; using iWareCC.StationService; using iWareCC.ThreadService; using iWareCC.ThreadService._03_BZ12_机器人码包工位_; using iWareCC.ThreadService._04_BZ21_搬运整垛机器人_; using iWareCC.WCF; using iWareCommon.Common.Globle; using iWareCommon.Utils; using iWareModel; using iWareModel.Entity.AGV; using iWareSql.DataAccess; using iWareSql.DBModel; using iWareSql.WmsDBModel; using Newtonsoft.Json; using System; using System.Collections.Generic; using System.Data; using System.Data.Entity.Core.Metadata.Edm; using System.Drawing; using System.Linq; using System.Linq.Expressions; using System.Net; using System.ServiceModel; using System.Threading; using System.Windows.Forms; using XiGang.Core.Model; using XiGang.Core.Model.ViewModels; using static WZ.Useful.Commons.NativeMethods; namespace iWareCC { public partial class FormCC : Form { /// /// 全局-配置报警信息列表 /// public static DeviceWarningOutput configDeviceWarningList = DeviceWarningHandler.GetConfigWarningList(); /// /// 全局—是否可以运行执行出库模式 /// public static bool IsAllowRunOutMode = false; /// /// 当前下发出库任务的包号 /// public static string currHandlerPackageCodeForIssueOutboundTask = ""; /// /// 1号堆垛机入库口扫码强制验证通过 /// public static bool Srm1_IN_SMQZYZTG = false; /// /// 2号堆垛机入库口扫码强制验证通过 /// public static bool Srm2_IN_SMQZYZTG = false; /// /// 3号堆垛机入库口扫码强制验证通过 /// public static bool Srm3_IN_SMQZYZTG = false; /// /// 4号堆垛机入库口扫码强制验证通过 /// public static bool Srm4_IN_SMQZYZTG = false; AutoSizeFormClass asc_panel_DeviceTaskList = new AutoSizeFormClass(); AutoSizeFormClass asc_panel_DeviceTaskList_dgvPartTask_Finished = new AutoSizeFormClass(); AutoSizeFormClass asc_panel_dataGridView__OutTaskList = new AutoSizeFormClass(); AutoSizeFormClass asc_panel_WaitPlanDetail = new AutoSizeFormClass(); AutoSizeFormClass asc_panel_DeviceTaskList_dataGridView_RgvStore = new AutoSizeFormClass(); AutoSizeFormClass asc_panel_dg_OutTaskRetryToMes = new AutoSizeFormClass(); public static string current_rgv_stationName; /// /// 1012站点持续有货的持续计数,一旦没有货了,就重置为0 /// public static int RGV_1012_HasCategory_COUNT = 0; /// /// 1011站点持续有货的持续计数,一旦没有货了,就重置为0 /// public static int RGV_1011_HasCategory_COUNT = 0; /// /// 1020持续无货时间,一旦有货了,就重置为0 /// public static int RGV_1020_NoHasCategory_COUNT = 0; public static int RGV_1001_HasCategory_COUNT = 0; public static int RGV_1003_HasCategory_COUNT = 0; public static int RGV_1005_HasCategory_COUNT = 0; public static int RGV_1008_HasCategory_COUNT = 0; /// /// 是否模拟PLC /// public static bool IsSimulationPLC = ConfigHelper.GetConfigBool("IsSimulationPLC"); private string currentCheckModelText = ""; const int cycleDelay_Device = 1000;//各个线程的延迟毫秒数 const int cycleDelay_Task = 1000; Thread startModelTipsThread;//启动线程提示 private bool isStartModelTipsThread = false;//是否启动了线程提示 private Color default_btn_Start_Color = Color.FromArgb(0, 192, 0);//默认的开始模拟按钮颜色 private Color ss_btn_Start_Color1 = Color.FromArgb(255, 255, 192);//开始模拟按钮后闪烁的颜色1 private Color ss_btn_Start_Color2 = Color.FromArgb(192, 192, 255);//开始模拟按钮后闪烁的颜色1 #region 信息获取线程 Thread tskSetSrmLable;//各种堆垛机工作状态的显示的控制线程 //Thread tskGetSrmTransStationInfo;//获取立库输送机信息的线程 Thread tskGetSrmConveyorInfo;//获取立库输送线的任务完成等信息的线程 Thread tskSetSrmTransLable;//各种立库输送机工作状态的显示的控制线程 Thread tskGetRgv1Info;//获取RGV信息的线程 Thread tskSetRgvLable;//各种Rgv工作状态的显示的控制线程 #endregion #region 堆垛机变量 /// /// 堆垛机的枚举变量列表 /// public static List SrmDeviceList; /// /// 堆垛机的实时数据对象字典 /// key:EDevice的Int值, Value:SrmView /// public static IDictionary srmViewDict; #endregion public static RgvView rgvView;//Rgv实体类 public static RgvService.RgvServiceClient rgvServiceClient = null; public static StationView stationView;//站点实体类 public static StationServiceClient stationServiceClient = null; public FormCC() { InitializeComponent(); SrmDeviceList = BusinessHelper.GetSrmDeviceList(); //初始化数据 InitSrmDict(); //暂时注释 //tp_Thread.Parent = null;//隐藏标签[线程控制] CheckForIllegalCrossThreadCalls = false; //设置界面初始化的选项 //暂时注释 /* this.rBNormal.Checked = SystemValue.rBNormal_Checked = true; this.rBPrepare.Checked = SystemValue.rBPrepare_Checked = false; this.rBDebug.Checked = SystemValue.rBDebug_Checked = false; this.ckBRgv上料任务.Checked = SystemValue.ckBRgv上料任务 = true; this.ckBRgv提前配板任务.Checked = SystemValue.ckBRgv提前配板任务 = false; //*/ //暂时 默认就选中自动模式 this.rBNormal.Checked = SystemValue.rBNormal_Checked = true; this.rbHand.Checked = SystemValue.rbHand_Checked = false; this.rBDebug.Checked = SystemValue.rBDebug_Checked = false; SetModelCheckBoxToSystemValue(); startModelTipsThread = new Thread(ShowTipsWhenStartModel); startModelTipsThread.Start(); #region 获取设备数据 var tskGetStationInfo = new Thread(GetStationInfo); tskGetStationInfo.Start(); var _GetStationWarningInfo = new Thread(GetStationWarningInfo); _GetStationWarningInfo.Start(); tskSetSrmLable = new Thread(SrmRead_Label); tskSetSrmLable.Start(); #endregion #region 设置显示UI #endregion #region 服务线程启动 //堆垛机任务服务线程启动 //var srmService = DeviceThreadServiceFactory.GetHandle(EDeviceType.堆垛机); // srmService.StartService(); //RGV任务服务线程启动 //var rgvService = DeviceThreadServiceFactory.GetHandle(EDeviceType.RGV); // rgvService.StartService(); new Thread(DataProcess_RobotBuffer_ModeChange.Handler).Start(); new Thread(DataProcess_RobotBuffer_IssueOutboundTask.Handler).Start(); new Thread(DataProcess_RobotBuffer_AutoQiTaoOutbound.Handler).Start(); new Thread(DataProcess_RobotBuffer_FinishTaskForOutbound.Handler).Start(); new Thread(DataProcess_RobotBuffer_ForceOutbound.Handler).Start(); new Thread(DataProcess_RobotBuffer_FinishTask.Handler).Start(); new Thread(DataProcess_BZ01.Handler).Start(); new Thread(DataProcess_269.Handler).Start(); new Thread(DataProcess_BZ39.Handler).Start(); new Thread(DataProcess_BZ39_IssueInboundTask.Handler).Start(); new Thread(DataProcess_BZ12.Hander).Start(); new Thread(DataProcess_BZ12_IssueTask.Handler).Start(); new Thread(DataProcess_BZ12_FinishTask.Handler).Start(); new Thread(DataProcess_BZ21.Hander).Start(); new Thread(DataProcess_BZ21_IssueTask.Handler).Start(); new Thread(DataProcess_BZ21_FinishTask.Handler).Start(); new Thread(DeleteData).Start(); new Thread(PushPackageCodeToMes.Handler).Start(); new Thread(PushPaperCutToMes.Handler).Start(); new Thread(DataProcess_ValidateQiTao.Handler).Start(); //*/ #endregion // new Thread(GetAgvVehicles).Start();//AGV车辆信息 // new Thread(OutTaskRetryToMes.Handler).Start(); //暂时不启用虚拟出入库功能 // new Thread(VirtualTaskNoOutPlanTaskHandler.Handler).Start(); } private void FormCC_Load(object sender, EventArgs e) { dateTimePicker_Start.Value = DateTime.Now; dateTimePicker_End.Value = DateTime.Now; /* trCancelBatchBackToStore = new Thread(CancelBatchBackToStore); trCancelBatchBackToStore.Start(); //*/ /* var tr_reverseSplitFinishProdOutStoreThread = new Thread(ReverseSplitFinishProdOutStoreThread); tr_reverseSplitFinishProdOutStoreThread.Start(); //*/ #region 对外发布WCF形式数据访问服务 try { #region 对外发布WCF形式数据访问服务 var lineServiceHost = new ServiceHost(typeof(CCWcfService)); lineServiceHost.Open(); lbl_WCFMsg.Text = "发布WCF成功," + lineServiceHost.BaseAddresses[0].AbsoluteUri; lbl_WCFMsg.ForeColor = Color.Green; #endregion } catch (Exception ex) { Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.CCWCFService, "发布WCF失败", ex); lbl_WCFMsg.Text = "发布WCF失败:" + ex.Message; lbl_WCFMsg.ForeColor = Color.Red; } #endregion this.lbl_IsSimulationPLC.Text = "是否模拟PLC:" + (IsSimulationPLC ? "是" : "否"); if (IsSimulationPLC) { this.panel_Model.BackColor = Color.Tomato; } else {//正式模式 stationServiceClient = new StationServiceClient(); } this.lbl_IsSimulationPLC.BackColor = IsSimulationPLC ? Color.Red : Color.Green; //此处快速启动 调试模式,用于开发用 //btn_Start_Click(null, null); } /// /// 设置1/2号堆垛机的前端显示 /// private void SrmRead_Label() { while (true) { Thread.Sleep(1000); try { var showNowTime = "(" + DateTimeHelper.ConvertToStringForOnlyShowTime(DateTime.Now) + ")"; //设置堆垛机任务下发和任务确认线程消息 this.lbl_Alert_DataProcess_BZ39_IssueInboundTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ39_IssueInboundTask; this.lbl_Alert_DataProcess_RobotBuffer_ForceOutbound.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_ForceOutbound; this.lbl_Alert_DataProcess_BZ12.Text = showNowTime + SystemWarningMsg._lbl_alert_DataProcess_BZ12; //设置堆垛机任务下发和任务完成确认线程消息 this.lbl_Alert_DataProcess_BZ12_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ12_FinishTask; this.lbl_Alert_DataProcess_BZ21_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ21_FinishTask; this.lbl_Alert_PushPaperCutToMes.Text = showNowTime + SystemWarningMsg._lbl_Alert_PushPaperCutToMes; this.lbl_Alert_PushPackageCodeToMes.Text = showNowTime + SystemWarningMsg._lbl_Alert_PushPackageCodeToMes; this.lbl_Alert_DataProcess_BZ12_IssueTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ12_IssueTask; this.lbl_DataProcess_ValidateQiTao.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_ValidateQiTao; this.lbl_Alert_DataProcess_RobotBuffer_FinishTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_FinishTask; this.lbl_DataProcess_BZ21_IssueTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ21_IssueTask; this.lbl_DataProcess_RobotBuffer_ModeChange.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_ModeChange; this.lbl_Alert_DataProcess_RobotBuffer_FinishTaskForOutbound.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_FinishTaskForOutbound; this.lbl_Alert_DeleteData.Text = showNowTime + SystemWarningMsg._lbl_Alert_DeleteData; this.lbl_Alert_DataProcess_RobotBuffer_AutoQiTaoOutbound.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_AutoQiTaoOutbound; this.lbl_Alter_DataProcess_BZ21.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_BZ21; this.lbl_alert_DataProcess_BZ39.Text = showNowTime + SystemWarningMsg._lbl_alert_DataProcess_BZ39; this.lbl_alert_DataProcess_BZ01.Text = showNowTime + SystemWarningMsg._lbl_alert_DataProcess_BZ01; this.lbl_alert_DataProcess_269.Text = showNowTime + SystemWarningMsg._lbl_alert_DataProcess_269; this.lbl_Alert_DataProcess_RobotBuffer_IssueOutboundTask.Text = showNowTime + SystemWarningMsg._lbl_Alert_DataProcess_RobotBuffer_IssueOutboundTask; //this.lblSrmPosX1.Text="111"; } catch (Exception ex) { continue; } } } #region 堆垛机线程和UI处理 #endregion #region RGV线程和UI处理 /// /// 设置Rgv的UI显示 /// /// private void SetRgvLable(object obj) { while (true) { Thread.Sleep(cycleDelay_Device); try { //lbRgv_Y.Text = "当前行走位置: " + rgv.R_RgvPosition; //lbRgv_X.Text = "当前区域位置: " + rgv.R_RgvPosition; //ERgvState _ERgvState = (ERgvState)Enum.Parse(typeof(ERgvState), rgv.R_State.ToString()); //lbRgvWorkState.Text = "工作状态: " + _ERgvState.ToString(); //lbRgvTaskId.Text = "任务号: " + rgv.R_TaskNo; //lbRgvIsAuto.Text = "工作模式: " + (rgv.ModeName); //lbRgvAlert.Text = rgv.R_AlarmCode.ToString(); //if (rgv.R_Alarm == false) //{ // //检测是否有心跳 // using (var rgvService = new RgvService.RgvServiceClient()) // { // //检测是否有心跳 // var isRgvHandShare = RgvBLL.IsRgvHandShare(rgvService); // if (!isRgvHandShare) // { // lbRgvAlert.Text = "RGV没有心跳"; // } // } //} //else //{ // lbRgvAlert.Text = rgv.R_AlarmCode.ToString(); //} //// ERgvEvent _ERgvEvent = (ERgvEvent)Enum.Parse(typeof(ERgvEvent), rgv.r_ev.ToString()); ////lbRgvEvent.Text = "事 件:" + _ERgvEvent.ToString(); //lbRgvTaskFinish.Text = "任务完成:" + rgv.R_TaskFinish; } catch (Exception) { continue; } } } #endregion #region 站点线程和UI处理 /// /// 设置站点的UI显示 /// /// private void SetStationLable(object obj) { while (true) { Thread.Sleep(cycleDelay_Device); try { //lbRgv_Y.Text = "当前行走位置: " + rgv.R_RgvPosition; //lbRgv_X.Text = "当前区域位置: " + rgv.R_RgvPosition; //ERgvState _ERgvState = (ERgvState)Enum.Parse(typeof(ERgvState), rgv.R_State.ToString()); //lbRgvWorkState.Text = "工作状态: " + _ERgvState.ToString(); //lbRgvTaskId.Text = "任务号: " + rgv.R_TaskNo; //lbRgvIsAuto.Text = "工作模式: " + (rgv.ModeName); //lbRgvAlert.Text = rgv.R_AlarmCode.ToString(); //if (rgv.R_Alarm == false) //{ // //检测是否有心跳 // using (var rgvService = new RgvService.RgvServiceClient()) // { // //检测是否有心跳 // var isRgvHandShare = RgvBLL.IsRgvHandShare(rgvService); // if (!isRgvHandShare) // { // lbRgvAlert.Text = "RGV没有心跳"; // } // } //} //else //{ // lbRgvAlert.Text = rgv.R_AlarmCode.ToString(); //} //// ERgvEvent _ERgvEvent = (ERgvEvent)Enum.Parse(typeof(ERgvEvent), rgv.r_ev.ToString()); ////lbRgvEvent.Text = "事 件:" + _ERgvEvent.ToString(); //lbRgvTaskFinish.Text = "任务完成:" + rgv.R_TaskFinish; } catch (Exception) { continue; } } } /// /// 获取Station信息 /// /// private void GetStationInfo(object obj) { while (true) { Thread.Sleep(1000);//1秒钟读取一次 try { if (stationServiceClient == null) { continue; } stationView = stationServiceClient.GetStationInfo((int)EDevice.Station); this.lbl_Mode_FJ.Text = "设备模式:" + PlcHelper.GetModeName(stationView.R_Mode_FJ); this.lbl_XinTiao_FJ.Text = "心跳:" + stationView.R_HandShake_FJ; this.lbl_Warning_FJ.Text = "报警类型:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_FJ); this.lbl_Mode_MB.Text = "设备模式:" + PlcHelper.GetModeName(stationView.R_Mode_MB); this.lbl_XinTiao_MB.Text = "心跳:" + stationView.R_HandShake_MB; this.lbl_Warning_MB.Text = "报警类型:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_MB); this.lbl_Mode_HB.Text = "设备模式:" + PlcHelper.GetModeName(stationView.R_Mode_HB); this.lbl_XinTiao_HB.Text = "心跳:" + stationView.R_HandShake_HB; this.lbl_Warning_HB.Text = "报警类型:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_HB); this.lbl_Mode_FX.Text = "设备模式:" + PlcHelper.GetModeName(stationView.R_Mode_FX); this.lbl_XinTiao_FX.Text = "心跳:" + stationView.R_HandShake_FX; this.lbl_Warning_FX.Text = "报警类型:" + PlcHelper.GetWarningTypeName(stationView.R_Warning_FX); ////显示RGV任务完成和完成确认信号 //this.lbl_R_RGV_Finish.Text = "RGV任务完成:" + rgvView.R_RGV_Finish; //this.lbl_W_RGV_FinishACK.Text = "RGV任务完成确认:" + rgvView.W_RGV_FinishACK; //this.lbl_RgvCoordinate.Text = "RGV实时坐标:" + rgvView.R_RGV_Coordinate; /* //解析RGV对象 foreach (var item in rgvView.R_RgvForReadCommList) { var control = ControlHelper.GetControlInstance(this.tPTransAsrs, "btn_" + item.StationCode); if (item.R_AlarmCode > 0) {//有报警 if (control != null) { var btn = control as Button; btn.BackColor = Color.Red; } } else { if (control != null) { var btn = control as Button; if (item.StationCode == ((int)EDevice.RGV1040).ToString()) { btn.BackColor = Color.Gold; } else if (item.StationCode == ((int)EDevice.拆盘机1020).ToString()) { btn.BackColor = Color.DodgerBlue; } else if (item.StationCode == ((int)EDevice.提升机1030).ToString()) { btn.BackColor = Color.SteelBlue; } else { btn.BackColor = Color.SeaGreen; } } } } //显示RGV报警信息 List warningAddressList = new List(); if (rgvView.R_Rgv_WarningDBList != null && rgvView.R_Rgv_WarningDBList.Length > 0) { tb_Rgv_Alter.Text = String.Join(",", rgvView.R_Rgv_WarningDBList.Select(x => x.Contextk__BackingField).ToArray()); //保存报警 var waringList = rgvView.R_Rgv_WarningDBList.ToList(); if (waringList != null && waringList.Count > 0) { for (int i = 0; i < waringList.Count; i++) { DeviceWarningHandler.SaveWarning(EDevice.RGV, iWareCommon.Utils.LogType.RgvThreadService, waringList[i].Codek__BackingField, waringList[i].Addressk__BackingField, waringList[i].Contextk__BackingField);//新增报警 warningAddressList.Add(waringList[i].Addressk__BackingField); } } } else { tb_Rgv_Alter.Text = ""; } DeviceWarningHandler.AutoCloseWarning(EDevice.RGV, iWareCommon.Utils.LogType.RgvThreadService, warningAddressList);//自动关闭报警 //*/ } catch (Exception ex) { rgvView = null; Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.StationThreadService, "获取站点信息出现异常:" + ex.Message, ex); continue; } } } /// /// 获取Station 报警信息 /// /// private async void GetStationWarningInfo(object obj) { while (true) { Thread.Sleep(2000);//1秒钟读取一次 try { if (stationServiceClient == null) { continue; } /* iWareCC.StationService.DeviceWarningInfo[] waringList = await stationServiceClient.GetWaringInfoListAsync((int)EDevice.Station, configDeviceWarningList.wmsConfigDeviceWarnings.ToArray()); //显示报警信息 List warningCodeList = new List(); if (waringList != null && waringList.Length > 0) { for (int i = 0; i < waringList.Length; i++) { var findObj = configDeviceWarningList.wms_config_device_warning_list.Where(x => x.WarningCode == waringList[i].Codek__BackingField).FirstOrDefault(); DeviceWarningHandler.SaveWarning(EDevice.Station, iWareCommon.Utils.LogType.StationThreadService, findObj.WarningCode, findObj.DeviceAreaCode, findObj.WarningContent, findObj.DeviceWarningType);//新增报警 warningCodeList.Add(findObj.WarningCode); } } else { } DeviceWarningHandler.AutoCloseWarning(EDevice.Station, iWareCommon.Utils.LogType.StationThreadService, warningCodeList);//自动关闭报警 //*/ } catch (Exception ex) { rgvView = null; Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.StationThreadService, "获取站点信息出现异常:" + ex.Message, ex); continue; } } } #endregion #region 其他线程 #region 定时删除数据 /// /// 定时删除数据 /// public void DeleteData() { while (true) { try { if (SystemValue.isAllowRuning_DeleteData && SystemValue.isStartedModel) { ClearDataHandler.Delete_Base_SysExceptionInfo(7); ClearDataHandler.Delete_Task_RequestLog(7); ClearDataHandler.Delete_Task_Part(10); ClearDataHandler.Delete_Device_Warning(30); ClearDataHandler.Delete_HttpRequestRecord(14); ClearDataHandler.Delete_MES_BTJReceiveReq(30); ClearDataHandler.Delete_MES_OnLineReq(30); LogTextHelper.BatchDeleteLog(); Thread.Sleep(8 * 60 * 60 * 1000);//每天8小时一次 } else { Thread.Sleep(6 * 1000); } } catch (Exception ex) { SystemWarningMsg._lbl_Alert_DeleteData = "出现异常:" + ex.Message; Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.CCWCFService, "定时删除数据 出现异常", ex); } finally { } } } #endregion #endregion #region 私有方法 /// /// 初始化实时堆垛机的字典 /// private static void InitSrmDict() { srmViewDict = new Dictionary(); SrmDeviceList.ForEach(singeDevice => { srmViewDict.Add((int)singeDevice, new SrmView()); }); } #endregion #region 公共 /// /// 公共堆垛机急停命令 /// private void CommonSrmEStop(EDevice _EDevice) { try { using (var opcClinet = new SrmService.SrmServiceClient()) { var result = opcClinet.SendEStop((int)_EDevice); Log4NetHelper.WriteInfoLog(iWareCommon.Utils.LogType.DataProcess_BZ39_IssueInboundTask, "字符串:" + JsonConvert.SerializeObject(result)); if (result.result) { WZ.Useful.Commons.MessageUtil.ShowTips("发送" + _EDevice.ToString() + "急停指令成功"); } else { WZ.Useful.Commons.MessageUtil.ShowTips("发送" + _EDevice.ToString() + "急停指令失败:" + result.resMsg); } } } catch (Exception ex) { WZ.Useful.Commons.MessageUtil.ShowError("发送" + _EDevice.ToString() + "急停指令异常:" + ex.Message); } } /// /// 堆垛机任务确认 /// /// /// private void CommonSrmConfirm(EDevice device, TextBox tbTaskId) { try { if (SystemValue.isStartedModel) { WZ.Useful.Commons.MessageUtil.ShowError("手动堆垛机任务确认,需要将模式关闭!"); return; } iWareCC.SrmService.SdaResEntity sdaResult = new SrmService.SrmServiceClient().ConfirmTaskFinish ((int)device, int.Parse(tbTaskId.Text.Trim())); if (sdaResult.result) { //tbSrm1TaskId.Clear(); Log4NetHelper.WriteInfoLog(iWareCommon.Utils.LogType.CCWCFService, "手动堆垛机任务确认成功,任务号:" + tbTaskId); } else { WZ.Useful.Commons.MessageUtil.ShowError("手动堆垛机任务确认失败:" + sdaResult.resMsg + "!"); Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.CCWCFService, "手动堆垛机任务确认失败:" + sdaResult.resMsg + "!,任务号:" + tbTaskId, null); } } catch (Exception ex) { WZ.Useful.Commons.MessageUtil.ShowError("手动堆垛机任务确认异常:" + ex.Message); Log4NetHelper.WriteErrorLog(iWareCommon.Utils.LogType.CCWCFService, "手动堆垛机任务确认异常:" + ex.Message, ex); } } private void CommonDeleteSrmTask(EDevice device) { if (SystemValue.isStartedModel) { WZ.Useful.Commons.MessageUtil.ShowError("手动删除堆垛机任务,需要将模式关闭!"); return; } MessageBoxButtons messButton = MessageBoxButtons.OKCancel; DialogResult dr = MessageBox.Show("确定要删除" + device.ToString() + "任务吗?", "确认", messButton); if (dr == DialogResult.OK)//如果点击“确定”按钮 { using (var opcClinet = new SrmService.SrmServiceClient()) { opcClinet.SendSrmDelete((int)device); } } else//如果点击“取消”按钮 { } } #endregion private void rBNormal_CheckedChanged(object sender, EventArgs e) { SetModelCheckBoxToSystemValue(); } private void rBDebug_CheckedChanged(object sender, EventArgs e) { SetModelCheckBoxToSystemValue(); } /// /// 根据选择的模式配置不同的值 /// private void SetModelCheckBoxToSystemValue() { SystemValue.rBNormal_Checked = this.rBNormal.Checked ? true : false; SystemValue.rbHand_Checked = this.rbHand.Checked ? true : false; SystemValue.rBDebug_Checked = this.rBDebug.Checked ? true : false; var title = "当前模式: "; if (SystemValue.rBNormal_Checked) {//选中了 自动模式 currentCheckModelText = "自动模式"; this.lbl_ModelText.Text = title + currentCheckModelText; this.gBoxThread.Enabled = false; SetAllCheckBoxChecked(true); } else if (SystemValue.rbHand_Checked) { currentCheckModelText = "手动模式"; this.lbl_ModelText.Text = title + currentCheckModelText; this.gBoxThread.Enabled = false; SetAllCheckBoxChecked(false); } else if (SystemValue.rBDebug_Checked) { currentCheckModelText = "调试模式"; this.lbl_ModelText.Text = title + currentCheckModelText; SetAllCheckBoxChecked(false); this.gBoxThread.Enabled = true; } else if (SystemValue.rBOnlyIn_Checked) { currentCheckModelText = "入库模式"; this.lbl_ModelText.Text = title + currentCheckModelText; SetAllCheckBoxChecked(true); //将特殊的取消 this.ck_DataProcess_BZ12_IssueTask.Checked = false; this.ck_DataProcess_BZ21_IssueTask.Checked = false; this.gBoxThread.Enabled = true; } else { currentCheckModelText = "无效模式"; } } /// /// 遍历所有的Checkbox,并配置是否被选中 /// /// private void SetAllCheckBoxChecked(bool _checked) { var contorls = this.groupBox1.Controls; foreach (var control in contorls) { if (control is CheckBox) { CheckBox c = (CheckBox)control; c.Checked = _checked; } } } /// /// 通用的checkbox改变事件 /// /// /// private void CommonCheckedChanged(object sender, EventArgs e) { //堆垛机1任务下发 DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_1, ckB_DataProcess_BZ39_IssueInboundTask); //堆垛机2任务下发 DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_2, ckBDataProcess_RobotBuffer_ForceOutbound); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_2_Finish, ckBDataProcess_BZ12_FinishTask); //堆垛机3任务下发 DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_3, ckBDataProcess_BZ12); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_SrmTaskThreadService_3_Finish, ckBDataProcess_BZ21_FinishTask); //RGV任务下发 DoCommonCheckedChanged(ref SystemValue.isAllowRuning_RgvThreadService_Finish, ckB_PushPaperCutToMes); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_RgvThreadService_Finish_BuChang, ck_PushPackageCodeToMes); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_HandlerIssuingTask, ck_DataProcess_BZ12_IssueTask); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_RobotBuffer_FinishTask, ck_DataProcess_RobotBuffer_FinishTask); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_MainTaskDecompose, ck_DataProcess_BZ21_IssueTask); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_RobotBuffer_ModeChange, ck_DataProcess_RobotBuffer_ModeChange); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_ValidateQiTao, ck_DataProcess_ValidateQiTao); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_RobotBuffer_FinishTaskForOutbound, checkBox_DataProcess_RobotBuffer_FinishTaskForOutbound); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DeleteData, ckDeleteData); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_RobotBuffer_AutoQiTaoOutbound, ckDataProcess_RobotBuffer_AutoQiTaoOutbound); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_BZ39, ck_DataProcess_BZ39); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_BZ01, ck_AutoIssueInStoreTask); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_269, ck_DataProcess_269); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_DataProcess_RobotBuffer_IssueOutboundTask, ck_DataProcess_RobotBuffer_IssueOutboundTask); DoCommonCheckedChanged(ref SystemValue.isAllowRuning_OutTaskRetryToMes, checkBox_DataProcess_BZ21); } private void DoCommonCheckedChanged(ref bool isAllowValue, CheckBox cb) { isAllowValue = cb.Checked ? true : false; } private void FormCC_SizeChanged(object sender, EventArgs e) { } /// /// 停止 /// /// /// private void btn_End_Click(object sender, EventArgs e) { //首先确认下,是不是选择的是 自动模式或者是 提前配板模式 //注意:这里增加模式时,要处理的 !!!! if (!(SystemValue.rBNormal_Checked || SystemValue.rbHand_Checked || SystemValue.rBDebug_Checked || SystemValue.rBOnlyIn_Checked )) { WZ.Useful.Commons.MessageUtil.ShowError("当前没有选择模式,停止动作无效!"); return; } if (isStartModelTipsThread == false) { WZ.Useful.Commons.MessageUtil.ShowError("当前没有模式在运行,停止动作无效!"); return; } MessageBoxButtons messButton = MessageBoxButtons.OKCancel; DialogResult dr = MessageBox.Show("确定要停止【" + currentCheckModelText + "】模式吗?", "停止模式", messButton); if (dr == DialogResult.OK)//如果点击“确定”按钮 { var doResult = CommonStopService(); if (!doResult) { return; } this.btn_Start.Text = "启动模式"; this.btn_Start.Enabled = true; SystemValue.isStartedModel = false; //启用选择模式的checkbox SetEnableForModelRadioButton(true); //this.rBNormal.Enabled = true; //this.rBClose.Enabled = true; //this.rBDebug.Enabled = true; //this.rBPrepare.Enabled = true; //this.rBPersonRaw.Enabled = true; //this.rBInOutStore.Enabled = true; //this.rBCancelBatchBackToStore.Enabled = true; //不需要重新关闭checkbox //SetAllCheckBoxChecked(false); isStartModelTipsThread = false; this.btn_Start.BackColor = default_btn_Start_Color;//还原颜色 } else//如果点击“取消”按钮 { } } /// /// 控制模式中的RadioButton禁启用 /// /// private void SetEnableForModelRadioButton(bool enabled) { var ctls = this.panel_Model.Controls; foreach (var item in ctls) { if (item is RadioButton) { RadioButton rb = (RadioButton)item; rb.Enabled = enabled; } } } /// /// 启动 /// /// /// private void btn_Start_Click(object sender, EventArgs e) { //首先确认下,是不是选择的是 自动模式或者是 提前配板模式 if (!(SystemValue.rBNormal_Checked || SystemValue.rbHand_Checked || SystemValue.rBDebug_Checked || SystemValue.rBOnlyIn_Checked )) { WZ.Useful.Commons.MessageUtil.ShowError("请选择其中一个模式!"); return; } MessageBoxButtons messButton = MessageBoxButtons.OKCancel; DialogResult dr = MessageBox.Show("确定要启动【" + currentCheckModelText + "】模式吗?", "启动模式", messButton); if (dr == DialogResult.OK)//如果点击“确定”按钮 { using (WmsDBModel edm = new WmsDBModel()) { var ccSystem = BasicDataSetHandler.GetCCSystem(edm); if (ccSystem == null) { WZ.Useful.Commons.MessageUtil.ShowError("请联系管理员维护系统调度相关的数据!"); return; }; //判断是否是自己开启的软件 if (!string.IsNullOrEmpty(ccSystem.Machine) && ccSystem.Machine != Dns.GetHostName()) {//默认的空值 WZ.Useful.Commons.MessageUtil.ShowError(string.Format("调度系统已经在其他地方启动配板模式,机器名:{0},启动时间:{1}!" , ccSystem.Machine, DateTimeHelper.ConvertToString(ccSystem.OnLineTime))); return; } ccSystem.BasicDataValue = SystemValue.SystemStartGuid = Guid.NewGuid().ToString(); ccSystem.OnLineTime = DateTime.Now; ccSystem.Machine = Dns.GetHostName(); int i = edm.SaveChanges(); if (i <= 0) { WZ.Useful.Commons.MessageUtil.ShowError("保存系统调度相关的数据失败!"); return; } } this.btn_Start.Text = "【" + currentCheckModelText + "】模式运行中..."; this.btn_Start.Enabled = false; this.btn_End.Enabled = true; SystemValue.isStartedModel = true; //禁用选择模式的checkbox SetEnableForModelRadioButton(false); //this.rBNormal.Enabled = false; //this.rBClose.Enabled = false; //this.rBDebug.Enabled = false; //this.rBPersonRaw.Enabled = false; //this.rBPrepare.Enabled = false; //this.rBInOutStore.Enabled = false; isStartModelTipsThread = true; } else//如果点击“取消”按钮 { } } /// /// 公共停止服务的处理 /// /// private bool CommonStopService() { using (WmsDBModel edm = new WmsDBModel()) { var ccSystem = BasicDataSetHandler.GetCCSystem(edm); if (ccSystem == null) { WZ.Useful.Commons.MessageUtil.ShowError("请联系管理员维护系统调度相关的数据!"); return false; }; //判断是否是自己开启的软件模式 if (SystemValue.SystemStartGuid == ccSystem.BasicDataValue) { ccSystem.BasicDataValue = "000000";//默认的空值 ccSystem.OnLineTime = null; ccSystem.Machine = string.Empty; ccSystem.LastMachine = Dns.GetHostName(); ccSystem.LastUnLineTime = DateTime.Now; ccSystem.UpdateTime = DateTime.Now; int i = edm.SaveChanges(); if (i <= 0) { WZ.Useful.Commons.MessageUtil.ShowError("保存系统调度相关的数据失败!"); return false; } } } return true; } private void FormCC_FormClosing(object sender, FormClosingEventArgs e) { MessageBoxButtons messButton = MessageBoxButtons.OKCancel; DialogResult dr = MessageBox.Show("确定要退出吗?", "确认", messButton); if (dr == DialogResult.OK)//如果点击“确定”按钮 { try { var doResult = CommonStopService(); if (!doResult) { e.Cancel = true; return; } e.Cancel = false; } catch (Exception ex) { WZ.Useful.Commons.MessageUtil.ShowError("出现错误!" + ex.Message); e.Cancel = true; } } else//如果点击“取消”按钮 { e.Cancel = true; } } private void FormCC_FormClosed(object sender, FormClosedEventArgs e) { try { Dispose(); } catch (Exception) { } Environment.Exit(0); } /// /// 模式启动后,按钮闪烁 /// /// private void ShowTipsWhenStartModel(object obj) { while (true) { Thread.Sleep(1000); if (isStartModelTipsThread) { try { this.btn_Start.BackColor = ss_btn_Start_Color2; Thread.Sleep(1000); this.btn_Start.BackColor = ss_btn_Start_Color1; } catch (Exception) { continue; } } else { if (this.btn_Start.BackColor != default_btn_Start_Color) { this.btn_Start.BackColor = default_btn_Start_Color;//还原颜色 } } this.lbl_RobotMode.Text = "缓存岛机器人模式:" + (IsAllowRunOutMode ? "出库模式" : "入库模式"); this.lbl_currHandlerPackageCodeForIssueOutboundTask.Text = "当前下发出库任务的包号:" + currHandlerPackageCodeForIssueOutboundTask; } } private void panel27_Paint(object sender, PaintEventArgs e) { } private void button5_Click(object sender, EventArgs e) { if (SystemValue.isStartedModel) { WZ.Useful.Commons.MessageUtil.ShowError("手动库位维护,需要将模式关闭!"); return; } //手动库位维护 SrmStockForm frm = new SrmStockForm(); frm.ShowDialog(); } private void btn_TongJi_Click(object sender, EventArgs e) { //统计 int store_FDJ = 0;//现有发动机数 int store_EmptySalver = 0;//空托盘数量 int store_EmptySalver_TS = 0;//空托盘托数 int count_In_FDJ = 0;//查询某天入库了多少发动机 int count_In_EmptySalver = 0;//查询某天入库了多少 空托盘 int count_In_EmptySalver_TS = 0;//查询某天入库了多少 空托盘托数 int count_Out_FDJ = 0;//查询某天出库了多少发动机 int count_Out_EmptySalver = 0;//查询某天出库了多少 空托盘 int count_Out_EmptySalver_TS = 0;//查询某天出库了多少 空托盘托数 int count_ZY_EmptySalver = 0;//查询某天转运了多少 空托盘 int count_ZY_EmptySalver_TS = 0;//查询某天转运了多少 空托盘托数 //某段时间的统计 var str_start = this.dateTimePicker_Start.Value.ToString("yyyy-MM-dd" + " " + "00:00:00"); var str_end = this.dateTimePicker_End.Value.ToString("yyyy-MM-dd" + " " + "23:59:59"); var start = Convert.ToDateTime(str_start); var end = Convert.ToDateTime(str_end); int allPlacesCount = 0; using (DbModel edm = new DbModel()) { var queryMaterialType_一般物料 = (int)MaterialTypeEnum.一般物料; var queryMaterialType_托盘 = (int)MaterialTypeEnum.托盘; var queryInOutFlag_In = (int)MainInOutFlagEnum.入库; var queryInOutFlag_Out = (int)MainInOutFlagEnum.出库; var queryInOutFlag_ZY = (int)MainInOutFlagEnum.转运; var allPlaces = edm.Base_Station.Where(x => x.IsSrmStation == true).ToList(); allPlaces = StationHandler.FindCommonFilter(allPlaces); allPlacesCount = allPlaces.Count; store_FDJ = edm.V_Store.Where(x => x.MaterialType == queryMaterialType_一般物料).Count(); store_EmptySalver_TS = edm.V_Store.Where(x => x.MaterialType == queryMaterialType_托盘).Count(); store_EmptySalver = store_EmptySalver_TS == 0 ? 0 : edm.V_Store.Where(x => x.MaterialType == queryMaterialType_托盘).Sum(x => (int)x.Qty); //查询某天入库了多少发动机 var taskState = (int)MainTaskStatusEnum.已完成; count_In_FDJ = edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_一般物料 && x.InOutFlag == queryInOutFlag_In && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Count(); //查询某天入库了多少托盘 count_In_EmptySalver_TS = edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_In && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Count(); count_In_EmptySalver = count_In_EmptySalver_TS == 0 ? 0 : edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_In && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Sum(x => (int)x.Qty); //查询某天出库了多少发动机 count_Out_FDJ = edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_一般物料 && x.InOutFlag == queryInOutFlag_Out && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Count(); //查询某天入库了多少托盘 count_Out_EmptySalver_TS = edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_Out && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Count(); count_Out_EmptySalver = count_Out_EmptySalver_TS == 0 ? 0 : edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_Out && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end)).Sum(x => (int)x.Qty); //查询某天转运了多少托盘(注意:只查询去1014位置的) count_ZY_EmptySalver_TS = edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_ZY && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end) && x.RealToPlace == "1014").Count(); count_ZY_EmptySalver = count_ZY_EmptySalver_TS == 0 ? 0 : edm.Task_Main.Where(x => x.MaterialType == queryMaterialType_托盘 && x.InOutFlag == queryInOutFlag_ZY && x.TaskState == taskState && (x.FinishTime >= start && x.FinishTime <= end) && x.RealToPlace == "1014").Sum(x => (int)x.Qty); } //显示 //var aa = "\r\n"; var str = ""; str += "时间范围: " + str_start + "至" + str_end + " \r\n"; str += "==================【库存】========================= \r\n"; str += "现有发动机数: " + store_FDJ + " \r\n"; str += "现有空托盘数: " + store_EmptySalver + " \r\n"; str += "现有空托盘托数: " + store_EmptySalver_TS + " \r\n"; str += "总库位" + allPlacesCount + ",有发动机或托盘库位" + (store_FDJ + store_EmptySalver_TS) + ",库存占比: " + CSharpHelper.ExecPercent((store_FDJ + store_EmptySalver_TS), allPlacesCount) + " \r\n"; str += "\r\n"; str += "==================【入库】========================= \r\n"; str += "入库发动机数: " + count_In_FDJ + " \r\n"; str += "入库空托盘数: " + count_In_EmptySalver + " \r\n"; str += "入库空托盘托数: " + count_In_EmptySalver_TS + " \r\n"; str += "\r\n"; str += "==================【出库】========================= \r\n"; str += "出库发动机数: " + count_Out_FDJ + " \r\n"; str += "出库空托盘数: " + count_Out_EmptySalver + " \r\n"; str += "出库空托盘托数: " + count_Out_EmptySalver_TS + " \r\n"; str += "\r\n"; str += "==================【转运托盘】========================= \r\n"; str += "转运空托盘数: " + count_ZY_EmptySalver + " \r\n"; str += "转运空托盘托数: " + count_ZY_EmptySalver_TS + " \r\n"; str += "\r\n"; this.tb_TongJi.Text = str; } private void checkBox_NowDay_CheckedChanged(object sender, EventArgs e) { if (this.checkBox_NowDay.Checked) { dateTimePicker_Start.Value = DateTime.Now; dateTimePicker_End.Value = DateTime.Now; } } private void rBOnlyIn_CheckedChanged(object sender, EventArgs e) { SetModelCheckBoxToSystemValue(); } private void btnSMQZYZTG1_Click(object sender, EventArgs e) { DobtnSMQZYZTG(EDevice.一号堆垛机); } private void DobtnSMQZYZTG(EDevice device) { MessageBoxButtons messButton = MessageBoxButtons.OKCancel; DialogResult dr = MessageBox.Show("注意:入库口扫码强制验证通过功能,仅适用于扫码器没有扫到码,但是实际托盘码和堆垛机要执行的任务托盘码一致的情况!如果堆垛机要执行的任务跟实际托盘码不符,请不要点击该按钮,及时联系管理员过来处理。您确定要操作吗?", "确认", messButton); if (dr == DialogResult.OK)//如果点击“确定”按钮 { var stationCode = MyExtendHelper.GetRgvStationCodeBySrm(device); var srm = FormCC.srmViewDict[(int)device]; //只有当堆垛机有任务执行时,并且是入库任务的时候才判断 var realSrmSourcePlace = (int)device + "-" + srm.SrmSourcePlace; if (srm.R_TaskNo > 0 && (srm.R_State == (int)ESrmState.取货中 || srm.R_State == (int)ESrmState.取货定位中) && SysGloble.Dict_SpecialPlace_IN.ContainsKey(realSrmSourcePlace)) { var result = MyExtendHelper.WriteScanValidateACK(false, "入库口扫码强制验证通过", stationCode, srm.R_TaskNo, true, "", ""); if (result) { MyExtendHelper.SetSrm_IN_SMQZYZTG(device, true); MessageBox.Show("入库口扫码强制验证通过 成功!"); } else { MessageBox.Show("入库口扫码强制验证通过 失败!"); } } else { MessageBox.Show(device.ToString() + "任务号不是大于0,或者 状态不是 '取货中'或'取货定位中',不允许操作"); } } else//如果点击“取消”按钮 { } } private void button22_Click(object sender, EventArgs e) { var cargNo = this.tb_wlm.Text.Trim(); var ret = WmsRequestHelper.test_getEngineInfo(cargNo); //转换后 MesRetModel2 retModel = JsonConvert.DeserializeObject>(ret); this.tb_TongJi.Text = "MES返回:" + ret + "\r\n" + "转换后:" + "\r\n" + JsonConvert.SerializeObject(retModel) ; } private void button23_Click(object sender, EventArgs e) { var cargNo = this.tb_wlm.Text.Trim(); var ret = WmsRequestHelper.test_btjReceive(cargNo); //转换后 MessageModel retModel = JsonConvert.DeserializeObject>(ret); this.tb_TongJi.Text = "WMS返回:" + ret + "\r\n" + "转换后:" + "\r\n" + JsonConvert.SerializeObject(retModel); } private void lbl_Alert_Place1014ClearStoreTask_Click(object sender, EventArgs e) { } private void button24_Click(object sender, EventArgs e) { //强制该包号出库 var packageCode = this.tb_PackageCode.Text.Trim(); var alertMsg = ""; CC_DataProcess_RobotBuffer_ForceOutbound.Handler(packageCode, ref alertMsg); if (!string.IsNullOrEmpty(alertMsg)) { MessageBox.Show("错误:" + alertMsg); } else { MessageBox.Show("已处理"); } } private void button25_Click(object sender, EventArgs e) { var packageCode = this.tb_PackageCode.Text.Trim(); var alertMsg = ""; using (WmsDBModel db = new WmsDBModel()) { var upiList = db.mes_batchOrderUPI_new.Where(x => x.PackageCode == packageCode).ToList(); foreach (var item in upiList) { item.AreaCode = (int)AreaCodeEnum.无区域; item.UpiStatus = (int)UpiStatusEnum.初始; } var pList = db.mes_package_gather.Where(x => x.PackageCode == packageCode).ToList(); foreach (var item in pList) { item.AreaCode = (int)AreaCodeEnum.无区域; item.UpiStatus = (int)UpiStatusEnum.初始; } //清空队列数据 var list = db.mes_upi_linequeue.ToList(); db.mes_upi_linequeue.RemoveRange(list); db.SaveChanges(); } if (!string.IsNullOrEmpty(alertMsg)) { MessageBox.Show("错误:" + alertMsg); } else { MessageBox.Show("已处理"); } } private void button1_Click(object sender, EventArgs e) { var alertMsg = ""; using (WmsDBModel db = new WmsDBModel()) { //查询立体库中的upi列表 var quanList = db.wms_stock_quan.ToList().Select(x => x.Upi).ToList(); var upiList = db.mes_batchOrderUPI_new.Where(x => !quanList.Contains(x.UPI)).ToList(); foreach (var item in upiList) { item.AreaCode = (int)AreaCodeEnum.无区域; item.UpiStatus = (int)UpiStatusEnum.初始; } var packageCodeList = upiList.Select(x => x.PackageCode).ToList(); var pList = db.mes_package_gather.Where(x => packageCodeList.Contains(x.PackageCode)).ToList(); foreach (var item in pList) { item.AreaCode = (int)AreaCodeEnum.无区域; item.UpiStatus = (int)UpiStatusEnum.初始; } //清空队列数据 var list = db.mes_upi_linequeue.ToList(); db.mes_upi_linequeue.RemoveRange(list); db.SaveChanges(); } if (!string.IsNullOrEmpty(alertMsg)) { MessageBox.Show("错误:" + alertMsg); } else { MessageBox.Show("已处理"); } } private void btn1_Click(object sender, EventArgs e) { var taskNo = this.tb_taskNo.Text.Trim(); var alertMsg = ""; using (WmsDBModel wmsDB = new WmsDBModel()) { var task = wmsDB.wms_rbline_task.Where(x => x.TaskNo == taskNo && x.RbTaskType == (int)RbTaskTypeEnum.入库任务 && x.TaskStatus == (int)TaskStatusEnum.已下发).FirstOrDefault(); if (task == null) { MessageBox.Show("没找到任务"); return; } var upiCode = task.Upi; var upiObj = wmsDB.mes_batchOrderUPI_new.Where(x => x.UPI == upiCode).FirstOrDefault(); if (upiObj == null) { MessageBox.Show($"根据UPI:{upiCode}没有找到对象 "); return; } //增加库存 wms_stock_quan qun = new wms_stock_quan() { Id = Yitter.IdGenerator.YitIdHelper.NextId(), Upi = upiCode, PlanNo = task.PlanNo, DetailName = upiObj.DetailName, OrderId = task.OrderId, CreateTime = DateTime.Now, CreateUserName = "CC", InTime = DateTime.Now, OperReason = "入库", PackageCode = task.PackageCode, Length = task.Length, Width = task.Width, Thk = task.Thk, PlaceCode = task.PlaceCode, StockStatus = (int)StockStatusEnum.在库, StockStatusName = StockStatusEnum.在库.ToString(), }; wmsDB.wms_stock_quan.Add(qun); task.TaskStatus = (int)TaskStatusEnum.已完成; task.FinishedTime = DateTime.Now; var place = StationHandler.GetPlaceByPlaceCode(task.PlaceCode, wmsDB); place.PlaceStatus = (int)PlaceStatusEnum.正常; WmsRecordUpiProcessHandler.SaveWmsRecordUpiProcess(wmsDB, upiObj, task.PlaceCode, "缓存入库完成:" + task.PlaceCode); wmsDB.SaveChanges(); } if (!string.IsNullOrEmpty(alertMsg)) { MessageBox.Show("错误:" + alertMsg); } else { MessageBox.Show("已处理"); } } } }