using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using DBFactory; using System.Net.Sockets; using System.Threading; using System.ServiceModel; namespace wcfControlMonitorClient { /// /// Creator:Richard.liu /// 设备指令队列管理 /// public partial class FrmModifyMonitor : Form { string _monstatus = " F_Status>=-1 "; Model.MDevice _device = null; private static FrmModifyMonitor _formInstance; public static FrmModifyMonitor FormInstance { get { if (_formInstance == null) { _formInstance = new FrmModifyMonitor(); } return _formInstance; } set { _formInstance = value; } } DBOperator dbo = CStaticClass.dbo; DBOperator dboM = CStaticClass.dboM; public FrmModifyMonitor() { InitializeComponent(); _formInstance = this; } private void cmMonitor_Opening(object sender, CancelEventArgs e) { if (this.dgvMonitor.CurrentRow == null) { TSMonitor.Visible = false; TSMManager.Visible = false; TSMonitorinfo.Visible = false; TSMmonitorOK.Visible = false; TSMRestore.Visible = false; TSMmonitorDel.Visible = false; toolStripSeparator2.Visible = false; tsmAGV.Visible = false; tsmAGVGet.Visible = false; tsmAGVSend.Visible = false; tsmAGVBank.Visible = false; tsmAGVGoods.Visible = false; return; } if (Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["调度任务索引"].Value) > 0) { TSMonitor.Visible = true; TSMManager.Visible = true; TSMonitorinfo.Visible = true; //TSMSimulateRun.Visible = true; TSMmonitorOK.Visible = true; //TSMmonitorDel.Visible = true; TSMRestore.Visible = true; toolStripSeparator2.Visible = true; #region 显示的信息 int deviceindex = Convert.ToInt32(dgvMonitor.CurrentRow.Cells["设备索引"].Value);//设备编号 string devicename = this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString();//设备名称 int DeviceKind = 0; //= ccf.GetDeviceKindIdx(deviceindex);//设备类型 _device = Model.CGetInfo.GetDeviceInfo(deviceindex); //20100108 if (_device != null) { DeviceKind = _device.DeviceKind; } string info = string.Empty; TSMManager.Text = string.Format("调度任务索引:{0},任务类型:{1},条码:{2}", this.dgvMonitor.CurrentRow.Cells["调度任务索引"].Value.ToString(), this.dgvMonitor.CurrentRow.Cells["任务类型"].Value.ToString(),dgvMonitor.CurrentRow.Cells["条码"].Value.ToString()); TSMonitor.Text = string.Format("设备指令索引:{0}", this.dgvMonitor.CurrentRow.Cells["设备指令索引"].Value.ToString()); int order = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["设备命令索引"].Value);//命令 string ordername = this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString();//命令名称 int Z = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["起点Z"].Value);//起点Z int X = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["起点X"].Value);//起点X int Y = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["起点Y"].Value);//起点Y int Z1 = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["终点Z"].Value);//终点Z int X1 = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["终点X"].Value);//终点X int Y1 = Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["终点Y"].Value);//终点Y int fork = 0; if (dgvMonitor.CurrentRow.Cells["货叉"].Value.ToString() != "-") { fork = Convert.ToInt32(dgvMonitor.CurrentRow.Cells["货叉"].Value);//货叉编号 } string forkuse = "待分配"; //DeviceKind+ deviceindex ordername Z/X/Y if(fork==1) { forkuse = "近货叉"; } else if (fork==2) { forkuse = "远货叉"; } switch (DeviceKind) { case 1://堆垛机 switch (order) { case 1: info = string.Format("{0}回原点", deviceindex); break; case 2://将取,取 case 4: info = string.Format("{0}到货位{1:D2}排-{2:D2}列-{3:D2}层{4},货叉:{5}", deviceindex, Z, X, Y, ordername,forkuse); break; case 3: case 5: info = string.Format("{0}到货位{1:D2}排-{2:D2}列-{3:D2}层{4},货叉:{5}", deviceindex, Z1, X1, Y1, ordername, forkuse); break; case 6: info = string.Format("{0}从货位{1:D2}排-{2:D2}列-{3:D2}层取货,送货到{4:D2}排-{5:D2}列-{6:D2}层,货叉:{7}", deviceindex, Z, X, Y, Z1, X1, Y1, forkuse); break; } break; case 2://输送机 switch (order) { case 1: case 2: case 8: case 9: info = string.Format("{0}{1}", deviceindex, ordername); break; case 6: info = string.Format("{0}{1}货物到{2}", deviceindex, ordername, Z1); break; } break; case 4://RGV switch (order) { case 7: info = string.Format("{0}{1}到输送机{2}", deviceindex, ordername, Z); break; case 8: case 9: info = string.Format("{0}到输送机{1}{2}", deviceindex, Z, ordername); break; } break; } TSMonitorinfo.Text = string.Format("指令描述:{0}", info); #endregion //TSMManager.Text = "条码:" + this.dgvMonitor.CurrentRow.Cells["条码"].Value.ToString() + // ";调度任务索引:" + this.dgvMonitor.CurrentRow.Cells["调度任务索引"].Value.ToString(); //TSMonitor.Text = "设备指令索引:" + this.dgvMonitor.CurrentRow.Cells["设备指令索引"].Value.ToString(); ////string CorrelRGV = "12008,12016,12024,32008,32016,32024,42008,42016,42024";//-1,-3 //string Upok = "32027,32040";//+2,+6 //int device=Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells["设备索引"].Value); //TSMmonitorOK.DropDownItems.Clear(); //if (CorrelRGV.IndexOf(device.ToString()) >= 0) //{ // ToolStripMenuItem tsmi = new ToolStripMenuItem(Convert.ToInt32(device - 1).ToString()); // tsmi.Click += new EventHandler(TSMmonitorOK_Click); // TSMmonitorOK.DropDownItems.Add(tsmi); // ToolStripMenuItem tsmi1 = new ToolStripMenuItem(Convert.ToInt32(device - 3).ToString()); // TSMmonitorOK.DropDownItems.Add(tsmi1); // tsmi1.Click += new EventHandler(TSMmonitorOK_Click); //} //else if (Upok.IndexOf(device.ToString()) >= 0) //{ // ToolStripMenuItem tsmi = new ToolStripMenuItem(Convert.ToInt32(device +2).ToString()); // tsmi.Click += new EventHandler(TSMmonitorOK_Click); // TSMmonitorOK.DropDownItems.Add(tsmi); // ToolStripMenuItem tsmi1 = new ToolStripMenuItem(Convert.ToInt32(device + 6).ToString()); // tsmi1.Click += new EventHandler(TSMmonitorOK_Click); // TSMmonitorOK.DropDownItems.Add(tsmi1); //} //if (this.dgvMonitor.CurrentRow.Cells[3].Value.ToString() == "1001") //{ // TSMSimulateRun.Visible = false; // TSMmonitorOK.Visible = false; // TSMRestore.Visible = true; // toolStripSeparator2.Visible = false; // tsmAGV.Visible = true; // tsmAGVGet.Visible = true; // tsmAGVSend.Visible = true; // if (this.dgvMonitor.CurrentRow.Cells[5].Value.ToString() == "2")//1219空托盘回收 // { // tsmAGVGoods.Visible = false; // tsmAGVBank.Visible = true; // tsmAGVSend.Visible = false; // return; // } // else // { // tsmAGVSend.Visible = true; // tsmAGVBank.Visible = false; // } // if (this.dgvMonitor.CurrentRow.Cells[5].Value.ToString() == "3")//1220残托盘回收 // { // tsmAGVBank.Visible = false; // tsmAGVGoods.Visible = true; // tsmAGVSend.Visible = false; // return; // } // else // { // tsmAGVSend.Visible = true; // tsmAGVGoods.Visible = false; // } //} //else //{ tsmAGV.Visible = false; tsmAGVGet.Visible = false; tsmAGVSend.Visible = false; tsmAGVBank.Visible = false; tsmAGVGoods.Visible = false; //} } } private void TSMmonitorOK_Click(object sender, EventArgs e) { ToolStripMenuItem tsm = sender as ToolStripMenuItem; if (tsm.DropDownItems.Count > 0) return; int deviceindex = 0; int.TryParse(tsm.Text, out deviceindex); char[] cc = new char[1] { ':' }; string[] split = TSMonitor.Text.Split(cc); if (split[1] == "") return; try { DataView dv = dbo.ExceSQL("SELECT * FROM T_Monitor_Task Where F_MonitorIndex=" + Convert.ToInt32(split[1])).Tables[0].DefaultView; if (dv.Count > 0) { //20100108中间指令被报告完成时给与提示和警告 DataView dv0 = dbo.ExceSQL("SELECT MIN(F_MonitorIndex) AS mmi FROM dbo.T_Monitor_Task WHERE (F_ManageTaskIndex = " + dv[0]["F_ManageTaskIndex"] + ") AND (F_ManageTASKKINDINDEX = " + dv[0]["F_ManageTASKKINDINDEX"] + ")").Tables[0].DefaultView; if (dv0.Count > 0) { if ((dv0[0]["mmi"] != DBNull.Value) && (dv0[0]["mmi"].ToString() != split[1])) { if (MessageBox.Show("条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”之前还有没执行完成的调度任务,提前【动作完成】会造成调度任务混乱,您确认要继续操作吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning) != DialogResult.OK) { return; } } } dv0 = null; //20100108操作黑匣子增加托盘条码 if (MessageBox.Show("您确认条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”已经操作完成了吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } string sss = "设备索引:" + dv[0]["F_DeviceIndex"].ToString() + ";设备指令索引:" + dv[0]["F_MonitorIndex"].ToString(); //20100108操作黑匣子增加托盘条码 CommonClassLib.CCarryConvert.WriteDarkCasket("设备指令管理", "手工报告完成", "条码:" + dv[0]["F_TxtParam"].ToString(), sss); string errtext = string.Empty; if (deviceindex == 0) { deviceindex = Convert.ToInt32(dv[0]["F_DeviceIndex"]); } if (dv[0]["F_NumParam4"].ToString() != "0" && CStaticClass.GetDeviceKindIdx(deviceindex) == 2 && deviceindex != 19005) {//20120906输送机的送出指令,以终点输送机作为任务完成设备 deviceindex = Convert.ToInt32(dv[0]["F_NumParam4"]); } CStaticClass.WcfControl.BeginModifyMonitorTask(deviceindex,Convert.ToInt32(dv[0]["F_MonitorIndex"]), Model.CGeneralFunction.TASKFINISH, new AsyncCallback(ModifyMonitorTaskCallBack), null); //{ // MessageBox.Show(errtext, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); //} TSMMonitorRefresh_Click(); } } catch (Exception ex) { MessageBox.Show(ex.Message, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); } } private void TSMRestore_Click(object sender, EventArgs e) { char[] cc = new char[1] { ':' }; string[] split = TSMonitor.Text.Split(cc); if (split[1] == "") return; try { string errtext = string.Empty; int devKind; int mindex = Convert.ToInt32(split[1]); int fid = 0; int mankind =0; //20100108改为select * DataView dv = dbo.ExceSQL("select * from T_Monitor_Task where F_MonitorIndex=" + mindex).Tables[0].DefaultView; if (dv.Count > 0) { fid = Convert.ToInt32(dv[0]["F_ManageTaskIndex"]); mankind = Convert.ToInt32(dv[0]["F_ManageTASKKINDINDEX"]); //20100108中间指令被复位时给与提示和警告 DataView dv0 = dbo.ExceSQL("SELECT MIN(F_MonitorIndex) AS mmi FROM dbo.T_Monitor_Task WHERE (F_ManageTaskIndex = " + fid + ") AND (F_ManageTASKKINDINDEX = " + mankind + ")").Tables[0].DefaultView; if (dv0.Count > 0) { if ((dv0[0]["mmi"] != DBNull.Value) && (dv0[0]["mmi"].ToString() != mindex.ToString())) { if (MessageBox.Show("条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”之前还有没执行完成的调度任务,提前【复位】会造成调度任务混乱,您确认要继续操作吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning) != DialogResult.OK) { return; } } } dv0 = null; //20100108操作黑匣子增加托盘条码 if (MessageBox.Show("您确认条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”需要被重新发送和设备清零吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } //20091107 devKind =CStaticClass.GetDeviceKindIdx (Convert.ToInt32(dv[0]["F_DeviceIndex"])); if ((devKind == 6) && (dv[0]["F_AgvNo"] != DBNull.Value)) { if (MessageBox.Show("您要复位的AGV任务已经分配AGV车号:" + dv[0]["F_AgvNo"].ToString() + ",确认要继续重新下达AGV命令吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } } string sss = "设备索引:" + dv[0]["F_DeviceIndex"].ToString() + ";设备指令索引:" + dv[0]["F_MonitorIndex"].ToString(); //20100108操作黑匣子增加托盘条码 CommonClassLib.CCarryConvert.WriteDarkCasket("设备指令管理", "手工复位", "条码:" + dv[0]["F_TxtParam"].ToString(), sss); CStaticClass.WcfControl.BeginModifyMonitorTask(Convert.ToInt32(dv[0]["F_DeviceIndex"]), Convert.ToInt32(dv[0]["F_MonitorIndex"]), Model.CGeneralFunction.TASKRESTORE, new AsyncCallback(ModifyMonitorTaskCallBack), null); //{ // MessageBox.Show(errtext, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); //} TSMMonitorRefresh_Click(); } } catch (Exception ex) { MessageBox.Show(ex.Message, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); } } private void rbmonAll_CheckedChanged(object sender, EventArgs e) { RadioButton rb = (RadioButton)sender; if (rb.Checked == true) { _monstatus = " F_Status>=-1 "; } TSMMonitorRefresh_Click(); } private void TSMMonitorRefresh_Click() { this.dgvMonitor.DataSource = dbo.ExceSQL("select * from V_Monitor_Task where " + _monstatus + " order by 设备指令索引 asc ").Tables[0].DefaultView; } private void rbmonRun_CheckedChanged(object sender, EventArgs e) { //if (rbmonRun.Checked == true) //{ // _monstatus = " (F_Status>=1) "; //} //TSMMonitorRefresh_Click(); } private void rbmonWait_CheckedChanged(object sender, EventArgs e) { RadioButton rb = (RadioButton)sender; if (rb.Checked == true) { _monstatus = " F_Status=0 "; } TSMMonitorRefresh_Click(); } public void button1_Click(object sender, EventArgs e) {//20140218 try { if (this.textBox1.Text.Trim().Length == 0) return; string _manstatus = " F_Status>=-1 "; if (this.comboBox1.Text == "条码") { _monstatus = " 条码='" + this.textBox1.Text.Trim() + "' "; _manstatus = " 条码 like '%" + this.textBox1.Text.Trim() + "%' "; } if (this.comboBox1.Text == "设备指令索引") { _monstatus = " 设备指令索引='" + this.textBox1.Text.Trim() + "' "; _manstatus = " 调度任务索引='" + CStaticClass.GetManageTaskIndexfromMonitor(Convert.ToInt32(this.textBox1.Text.Trim())) + "' "; } if (this.comboBox1.Text == "调度任务索引") { _monstatus = " 调度任务索引='" + this.textBox1.Text.Trim() + "' "; _manstatus = " 调度任务索引='" + this.textBox1.Text.Trim() + "' "; } if (this.comboBox1.Text == "设备索引")//20130817richard { _monstatus = " F_Status<>0 and 设备索引='" + this.textBox1.Text.Trim() + "' "; int manFID = Convert.ToInt32(dbo.GetSingle("SELECT F_ManageTaskIndex,F_DeviceIndex,F_Status FROM T_Monitor_Task where F_Status<>0 and F_DeviceIndex='" + this.textBox1.Text.Trim() + "' ")); _manstatus = " 调度任务索引='" + manFID + "' "; } TSMMonitorRefresh_Click(); // this.dgvManager.DataSource = dbo.ExceSQL("select * from V_Manage_Task where " + _manstatus).Tables[0].DefaultView;// 上海晟碟 } catch (Exception ex) { MessageBox.Show(ex.Message, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); } } private void button2_Click(object sender, EventArgs e) { _monstatus = " F_Status>=-1 "; TSMMonitorRefresh_Click(); } private void dgvMonitor_DataSourceChanged(object sender, EventArgs e) { dgvMonitor.Columns["F_Status"].Visible = false; } private void FrmModifyMonitor_Load(object sender, EventArgs e) { rbmonRun_Click(sender, e); } private void tsmAGVGet_Click(object sender, EventArgs e) { string sql = ""; //由T_Monitor_Task表中获得F_NumParam2字段值 条件:消息返回的小车任务号 DataTable tableMonitorTask = dbo.ExceSQL("SELECT F_ManageTASKKINDINDEX,F_ManageTaskIndex,F_NumParam2,F_AgvTask,F_AgvNo FROM T_MONITOR_TASK WHERE F_DeviceIndex=1001 and F_MonitorIndex=" + this.dgvMonitor.CurrentRow.Cells[2].Value + "").Tables[0]; if (tableMonitorTask.Rows.Count > 0) { if (MessageBox.Show("您确认手工报告AGV叉货完成吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } sql = "UPDATE T_Monitor_Task SET F_Status = 2 WHERE (F_MonitorIndex =" + this.dgvMonitor.CurrentRow.Cells[2].Value + ")"; dbo.ExceSQL(sql); //由T_Base_AGV_Gate表中获得F_AGVGateDeviceIndex字段值 条件:T_Base_AGV_Gate.F_Address = T_Monitor_Task.F_NumParam2 DataTable tableAGVGate = dbo.ExceSQL("SELECT F_AGVGateDeviceIndex FROM T_BASE_AGV_GATE WHERE F_ADDRESS = " + Convert.ToInt32(tableMonitorTask.Rows[0]["F_NumParam2"]) + "").Tables[0]; if (tableAGVGate.Rows.Count > 0) { if (MessageBox.Show("您确定要把设备:" + tableAGVGate.Rows[0]["F_AGVGateDeviceIndex"] + "置成【无托盘】状态吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } //更改T_Base_Device表中的F_HaveGoods字段值为0。条件:T_Base_Device.F_DeviceIndex = T_Base_AGV_Gate.F_AGVGateDeviceIndex dbo.ExecuteSql("UPDATE T_BASE_DEVICE SET F_PALLETBARCODE='-',F_HAVEGOODS = 0 WHERE F_DEVICEINDEX = " + Convert.ToInt32(tableAGVGate.Rows[0]["F_AGVGateDeviceIndex"]) + ""); string errtext=string.Empty; if (tableMonitorTask.DefaultView[0]["F_ManageTASKKINDINDEX"].ToString() == "1") { //20090817给管理置无托盘信息 dboM.ExecuteSql("UPDATE T_ITEMDEVICE SET devicestatus ='0' WHERE devicecode = '" + tableAGVGate.Rows[0]["F_AGVGateDeviceIndex"] + "'"); } } string sss = "AGV车号:" + tableMonitorTask.Rows[0]["F_AgvNo"].ToString() + ";设备指令索引:" + this.dgvMonitor.CurrentRow.Cells[2].Value.ToString(); CommonClassLib.CCarryConvert.WriteDarkCasket("设备指令管理", "手工报告AGV叉货完成", tableMonitorTask.Rows[0]["F_AgvNo"].ToString() + "号车", sss); } else { MessageBox.Show("只有AGV任务才可以手工报告AGV叉货完成!", "误操作提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); return; } } private void tsmAGVSend_Click(object sender, EventArgs e) { //由T_Monitor_Task表中获得F_NumParam5字段值 条件:消息返回的小车任务号 DataTable tableMonitorTask = dbo.ExceSQL("SELECT F_TxtParam,F_NumParam5,F_AgvTask,F_AgvNo FROM T_MONITOR_TASK WHERE F_DeviceIndex=1001 and F_MonitorIndex=" + this.dgvMonitor.CurrentRow.Cells[2].Value + "").Tables[0]; if (tableMonitorTask.Rows.Count > 0) { if (MessageBox.Show("您确认手工报告AGV卸货完成吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } //由T_Base_AGV_Gate表中获得F_AGVGateDeviceIndex字段值 条件:T_Base_AGV_Gate.F_Address = T_Monitor_Task.F_NumParam2 DataTable tableAGVGate = dbo.ExceSQL("SELECT F_AGVGateDeviceIndex FROM T_BASE_AGV_GATE WHERE F_ADDRESS = " + Convert.ToInt32(tableMonitorTask.Rows[0]["F_NumParam5"]) + "").Tables[0]; if (tableAGVGate.Rows.Count > 0) { if (MessageBox.Show("您确定要把设备:" + tableAGVGate.Rows[0]["F_AGVGateDeviceIndex"] + "置成【有托盘】状态吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } //更改T_Base_Device表中的F_HaveGoods字段值为0。条件:T_Base_Device.F_DeviceIndex = T_Base_AGV_Gate.F_AGVGateDeviceIndex dbo.ExecuteSql("UPDATE T_BASE_DEVICE SET F_PALLETBARCODE='" + tableMonitorTask.Rows[0]["F_TxtParam"] + "',F_HAVEGOODS = 1 WHERE F_DEVICEINDEX = " + Convert.ToInt32(tableAGVGate.Rows[0]["F_AGVGateDeviceIndex"]) + ""); } string sss = "AGV车号:" + tableMonitorTask.Rows[0]["F_AgvNo"].ToString() + ";设备指令索引:" + this.dgvMonitor.CurrentRow.Cells[2].Value.ToString(); CommonClassLib.CCarryConvert.WriteDarkCasket("设备指令管理", "手工报告AGV卸货完成", tableMonitorTask.Rows[0]["F_AgvNo"].ToString() + "号车", sss); CStaticClass.WcfControl.BeginModifyMonitorTask(1001,Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells[2].Value), Model.CGeneralFunction.TASKFINISH ,new AsyncCallback(ModifyMonitorTaskCallBack), null); } else { MessageBox.Show("只有AGV任务才可以手工报告AGV放货完成!", "误操作提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); return; } } private void tsmAGVBank_Click(object sender, EventArgs e) { string errtext=string.Empty; CStaticClass.WcfControl.BeginModifyMonitorTask(1001,Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells[2].Value), Model.CGeneralFunction.TASKFINISH, new AsyncCallback(ModifyMonitorTaskCallBack), null); } private void tsmAGVGoods_Click(object sender, EventArgs e) { string errtext = string.Empty; CStaticClass.WcfControl.BeginModifyMonitorTask(1001,Convert.ToInt32(this.dgvMonitor.CurrentRow.Cells[2].Value), Model.CGeneralFunction.TASKFINISH ,new AsyncCallback(ModifyMonitorTaskCallBack), null); } private void dgvMonitor_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e) { foreach (DataGridViewRow DGVRow in this.dgvMonitor.Rows) { if (DGVRow != null) { if (Convert.ToInt32(DGVRow.Cells["f_status"].Value) >= 30) { DGVRow.DefaultCellStyle.BackColor = Color.Red; } } } } private void TSMmonitorDel_Click(object sender, EventArgs e) { char[] cc = new char[1] { ':' }; string[] split = TSMonitor.Text.Split(cc); if (split[1] == "") return; try { DataView dv = dbo.ExceSQL("SELECT * FROM T_Monitor_Task Where F_MonitorIndex=" + Convert.ToInt32(split[1])).Tables[0].DefaultView; if (dv.Count > 0) { //20100108中间指令被报告完成时给与提示和警告 DataView dv0 = dbo.ExceSQL("SELECT MIN(F_MonitorIndex) AS mmi FROM dbo.T_Monitor_Task WHERE (F_ManageTaskIndex = " + dv[0]["F_ManageTaskIndex"] + ") AND (F_ManageTASKKINDINDEX = " + dv[0]["F_ManageTASKKINDINDEX"] + ")").Tables[0].DefaultView; if (dv0.Count > 0) { if ((dv0[0]["mmi"] != DBNull.Value) && (dv0[0]["mmi"].ToString() != split[1])) { if (MessageBox.Show("条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”之前还有没执行完成的调度任务,提前【删除设备指令】会造成调度任务混乱,您确认要继续操作吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Warning) != DialogResult.OK) { return; } } } dv0 = null; //20100108操作黑匣子增加托盘条码 if (MessageBox.Show("您确认条码:" + dv[0]["F_TxtParam"].ToString() + ",设备名称:“" + this.dgvMonitor.CurrentRow.Cells["设备名称"].Value.ToString() + ";设备命令:" + this.dgvMonitor.CurrentRow.Cells["设备命令名称"].Value.ToString() + "”已经不需要设备执行了吗?", "操作提示:", MessageBoxButtons.OKCancel, MessageBoxIcon.Question) != DialogResult.OK) { return; } string sss = "设备索引:" + dv[0]["F_DeviceIndex"].ToString() + ";设备指令索引:" + dv[0]["F_MonitorIndex"].ToString(); //20100108操作黑匣子增加托盘条码 CommonClassLib.CCarryConvert.WriteDarkCasket("设备指令管理", "手工删除设备指令", "条码:" + dv[0]["F_TxtParam"].ToString(), sss); CStaticClass.WcfControl.BeginModifyMonitorTask(Convert.ToInt32(dv[0]["F_DeviceIndex"]), Convert.ToInt32(dv[0]["F_MonitorIndex"]), Model.CGeneralFunction.TASKDELETE, new AsyncCallback(ModifyMonitorTaskCallBack), null); //{ // MessageBox.Show(sss, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); //} TSMMonitorRefresh_Click(); } } catch (Exception ex) { MessageBox.Show(ex.Message, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); } } private void comboBox1_SelectedIndexChanged(object sender, EventArgs e) { try { string df = ""; string wherestr = " where 1=1 "; switch (this.comboBox1.Text) { case "条码": df = "条码"; break; case "调度任务索引": df = "调度任务索引"; break; case "设备指令索引": df = "设备指令索引"; wherestr = " where f_status<>0 "; break; case "设备索引": df = "设备索引";//20130817richard wherestr = " where f_status<>0 "; break; default: return; } //20100208 string sql = "select distinct " + df + " from V_Monitor_Task " + wherestr; DataView dv = dbo.ExceSQL(sql).Tables[0].DefaultView; if (dv.Count > 0) { this.textBox1.DataSource = null; this.textBox1.DisplayMember = df; this.textBox1.ValueMember = df; this.textBox1.DataSource = dv; } } catch (Exception ex) { throw ex; } } private void dgvMonitor_CellMouseDown(object sender, DataGridViewCellMouseEventArgs e) { if (e.Button == MouseButtons.Right)//20130402 { if ((e.RowIndex >= 0) && (e.ColumnIndex >= 0)) { //若行已是选中状态就不再进行设置 if (dgvMonitor.Rows[e.RowIndex].Selected == false) { dgvMonitor.ClearSelection(); dgvMonitor.Rows[e.RowIndex].Selected = true; } //只选中一行时设置活动单元格 if (dgvMonitor.SelectedRows.Count == 1) { dgvMonitor.CurrentCell = dgvMonitor.Rows[e.RowIndex].Cells[e.ColumnIndex]; } //弹出操作菜单 cmMonitor.Show(MousePosition.X, MousePosition.Y); } } } void ModifyMonitorTaskCallBack(IAsyncResult ar) { if (this.IsDisposed == true) return; string errtext = string.Empty; this.BeginInvoke(new MethodInvoker(delegate() { if (CStaticClass.WcfControl.EndModifyMonitorTask(out errtext, ar) == false) { MessageBox.Show(errtext, "操作提示:", MessageBoxButtons.OK, MessageBoxIcon.Error); } TSMMonitorRefresh_Click(); })); } private void FrmModifyMonitor_FormClosing(object sender, FormClosingEventArgs e) { _formInstance = null; } private void rbmonAll_Click(object sender, EventArgs e) { RadioButton rb = (RadioButton)sender; if (rb.Checked == true) { _monstatus = " F_Status>=-1 "; } TSMMonitorRefresh_Click(); } private void rbmonRun_Click(object sender, EventArgs e) { if (rbmonRun.Checked == true) { _monstatus = " (F_Status>=1) "; } TSMMonitorRefresh_Click(); } private void rbmonWait_Click(object sender, EventArgs e) { RadioButton rb = (RadioButton)sender; if (rb.Checked == true) { _monstatus = " F_Status=0 "; } TSMMonitorRefresh_Click(); } private void radioButton1_Click(object sender, EventArgs e) { RadioButton rb = (RadioButton)sender; if (rb.Checked == true) { //CStaticClass.RealRefresh = true; _monstatus = "(设备指令索引 IN(SELECT MIN(设备指令索引) FROM V_Monitor_Task GROUP BY 调度任务索引))"; //string sql = string.Format("SELECT * FROM V_Monitor_Task WHERE {0}", _monstatus); //this.dgvMonitor.DataSource = dbo.ExceSQL(sql).Tables[0].DefaultView; TSMMonitorRefresh_Click(); } } } }