using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; using CoreFS.CA06; using System.Collections; using Infragistics.Win.UltraWinGrid; using System.Diagnostics; namespace Core.LZMes.Client.QCM { public partial class QCM0308 : FrmBase { public QCM0308() { InitializeComponent(); } public override void ToolBar_Click(object sender, string ToolbarKey) { switch (ToolbarKey) { case"Query": this.DoQuery(); break; case "Judge": this.Judge(); break; case "Cancel": this.Cancel(); break; case "Export": this.DoExport(); break; } } private void Judge() { try { UltraGridRow ugr = this.ultraGrid1.ActiveRow; List list1 = new List(); if (ugr == null) return; string heat_no = ugr.Cells["HEAT_NO"].Value.ToString(); string material_no = ugr.Cells["MATERIAL_NO"].Value.ToString(); string design_key = ugr.Cells["DESIGN_KEY"].Value.ToString(); string grade_name = ugr.Cells["GRADE_NAME"].Value.ToString(); string username = this.UserInfo.GetUserName(); string assay_no = ""; foreach (UltraGridRow ugrs in this.ultraGrid2.Rows) { if (ugrs.Cells["CHECKBOX"].Text.ToString() == "True") { assay_no = ugrs.Cells["STD_TYPE"].Value.ToString(); list1.Add(assay_no); } } if (list1.Count == 0) { MessageBox.Show("请选择检验实绩!"); return; } CoreClientParam ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJhyElementsServiceImpl"; ccp.MethodName = "RlChemJudgeByHuman"; ccp.ServerParams = new object[] { heat_no, material_no, design_key, username, grade_name, list1 }; ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal); if (ccp.ReturnCode == -1) { return; } ugr.Delete(false); MessageBox.Show("判定成功!"); } catch (Exception EX) { MessageBox.Show(EX.ToString()); } //DoQuery(); } private void Cancel() { try { UltraGridRow ugr = this.ultraGrid4.ActiveRow; if (ugr == null) return; string material_no = ugr.Cells["material_no"].Value.ToString(); string username = this.UserInfo.GetUserName(); CoreClientParam ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJudgeChemicalServiceImpl"; ccp.MethodName = "CancelRJudge"; ccp.ServerParams = new object[] { material_no,username }; ccp = this.ExecuteNonQuery(ccp, CoreInvokeType.Internal); if (ccp.ReturnCode != -1) { MessageBox.Show("取消判定成功!"); } } catch (Exception ex) { System.Diagnostics.Debug.WriteLine(ex.ToString()); MessageBox.Show("系统出错,请联系管理人员", "警告"); } } private void DoQuery() { if (this.ultraTabControl1.Tabs[0].Selected) //待判信息 { DoQueryMe(); } if (this.ultraTabControl1.Tabs[1].Selected) //判定记录 { DoQueryRe(); } } //查询待判信息 private void DoQueryMe() { try { this.dataSet5.Clear(); string sbatchno = this.textBox1.Text.Trim(); string ebatchno = this.textBox2.Text.Trim(); string orderno = this.textBox3.Text.Trim();// 订单号 string psc = textBox4.Text.Trim(); //产品描述 string sbatchno1 = ""; string ebatchno1 = ""; sbatchno1 = this.textBox5.Text.Trim(); if (textBox5.Text.ToString() == "" || textBox6.Text.ToString() != "") { ebatchno1 = this.textBox6.Text.Trim(); } else { ebatchno1 = this.textBox5.Text.Trim(); } CoreClientParam ccp = new CoreClientParam(); string prodline = comboBox3.Text.ToString(); ccp.ServerName = "QCM.QCM03.QCM0303.QcmJudgeMeasureServiceImpl"; ccp.MethodName = "doQueryMaterialDetailsJR"; ccp.ServerParams = new object[] { this.dateTimePicker1.Value.ToString("yyyyMMdd"), this.dateTimePicker2.Value.ToString("yyyyMMdd"), sbatchno, ebatchno, orderno, psc, "R",prodline,sbatchno1,ebatchno1 }; ccp.SourceDataTable = this.dataSet5.Tables[0]; this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal); } catch (Exception ex) { System.Diagnostics.Debug.WriteLine(ex.ToString()); MessageBox.Show("系统出错,请联系管理人员", "警告"); } } //查询判定记录 private void DoQueryRe() { try { this.dataSet1.Clear(); string heatno = textBox1.Text.Trim(); string BOARD_NO = textBox2.Text.Trim(); string design_key = textBox3.Text.Trim(); string psc = textBox4.Text.Trim(); string prodline = comboBox3.Text.ToString(); string sbatchno = ""; string ebatchno = ""; sbatchno = this.textBox5.Text.Trim(); if (textBox5.Text.ToString() == "" || textBox6.Text.ToString() != "") { ebatchno = this.textBox6.Text.Trim(); } else { ebatchno = this.textBox5.Text.Trim(); } CoreClientParam ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJudgeChemicalServiceImpl"; ccp.MethodName = "GetJudgeRChemRecord"; ccp.ServerParams = new object[] { this.dateTimePicker1.Value.ToString("yyyyMMdd"), this.dateTimePicker2.Value.ToString("yyyyMMdd"), heatno, BOARD_NO, design_key, psc,"0",prodline,sbatchno,ebatchno }; ccp.SourceDataTable = this.dataSet1.Tables[0]; this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal); } catch (Exception ex) { System.Diagnostics.Debug.WriteLine(ex.ToString()); MessageBox.Show("系统出错,请联系管理人员", "警告"); } } private void ultraGrid4_AfterRowActivate(object sender, EventArgs e) { try { UltraGridRow ugr = this.ultraGrid4.ActiveRow; if (ugr == null) return; this.dataSet4.Clear(); string cic_id = ugr.Cells["CIC_ID"].Value.ToString(); CoreClientParam ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJhyElementsServiceImpl"; ccp.MethodName = "GetRChemeResult"; ccp.ServerParams = new object[] { cic_id }; ccp.SourceDataTable = this.dataSet4.Tables[0]; this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal); ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJhyElementsServiceImpl"; ccp.MethodName = "GetCheme"; ccp.ServerParams = new object[] { cic_id }; this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal); for (int i = 0; i < ccp.SourceDataTable.Rows.Count; i++) { foreach(UltraGridRow ugr5 in this.ultraGrid5.Rows) { if (ugr5.Cells[ccp.SourceDataTable.Rows[i]["phy_code_s"].ToString()].Value.ToString().Contains(ccp.SourceDataTable.Rows[i]["stdmin"].ToString()) && ugr5.Cells[ccp.SourceDataTable.Rows[i]["phy_code_s"].ToString()].Value.ToString().Contains(ccp.SourceDataTable.Rows[i]["stdmax"].ToString())) { ugr5.Cells[ccp.SourceDataTable.Rows[i]["phy_code_s"].ToString()].Appearance.BackColor = Color.Red; } } } } catch (Exception ex) { //System.Diagnostics.Debug.WriteLine(ex.ToString()); //MessageBox.Show("系统出错,请联系管理人员", "警告"); } } private void ultraGrid1_AfterRowActivate(object sender, EventArgs e) { try { UltraGridRow ugr = this.ultraGrid1.ActiveRow; if (ugr == null) return; this.dataSet3.Clear(); string design_key = ugr.Cells["DESIGN_KEY"].Value.ToString(); string smp_no = ugr.Cells["HEAT_NO"].Value.ToString(); string grade_name = ugr.Cells["GRADE_NAME"].Text.ToString(); CoreClientParam ccp = new CoreClientParam(); ccp.ServerName = "QCM.QCM03.QCM0301.QcmJhyElementsServiceImpl"; ccp.MethodName = "GetRChemeInfo"; ccp.ServerParams = new object[] { design_key, smp_no,grade_name }; ccp.SourceDataTable = this.dataSet3.Tables[0]; this.ExecuteQueryToDataTable(ccp, CoreInvokeType.Internal); UltraGridRow judge_row = null; foreach (UltraGridRow ugs in this.ultraGrid2.Rows) { ugs.Cells["CHECKBOX"].Value = ugs.Cells["CHECKBOXS"].Text.ToString(); if (!string.IsNullOrEmpty(ugs.Cells["CHECKBOXS"].Text) && ugs.Cells["CHECKBOXS"].Text.ToString() == "True") { judge_row = ugs; } } if (judge_row != null) { foreach (UltraGridRow ugs in this.ultraGrid2.Rows) { if (!string.IsNullOrEmpty(ugs.Cells["STD_TYPE"].Text) && ugs.Cells["STD_TYPE"].Text.ToString() == "放行标准(熔炼)") { for (int i = 0; i < ugs.Cells.Count; i++) { if (!string.IsNullOrEmpty(ugs.Cells[i].Text) && ugs.Cells[i].Text.ToString().Contains(" ")) { string[] str_arr = ugs.Cells[i].Text.ToString().Replace(" ", "#").Split('#'); if (str_arr.Length == 1) { if (str_arr[0].Contains("<=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[0].Replace("<=", "")) < double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } else if (str_arr[0].Contains(">=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[0].Replace(">=", "")) > double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } } else if (str_arr.Length == 2) { if (str_arr[0].Contains("<=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[0].Replace("<=", "")) < double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } else if (str_arr[0].Contains(">=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[0].Replace(">=", "")) > double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } if (str_arr[1].Contains("<=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[1].Replace("<=", "")) < double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } else if (str_arr[1].Contains(">=") && !string.IsNullOrEmpty(judge_row.Cells[i].Text)) { if (double.Parse(str_arr[1].Replace(">=", "")) > double.Parse(judge_row.Cells[i].Text.ToString())) { ugs.Cells[i].Appearance.BackColor = Color.Red; } } } } } } } } } catch (Exception ex) { System.Diagnostics.Debug.WriteLine(ex.ToString()); MessageBox.Show("系统出错,请联系管理人员", "警告"); } } private void QCM0308_Load(object sender, EventArgs e) { this.comboBox3.SelectedIndex = 0; this.ultraGrid4.DisplayLayout.Override.FilterUIType = FilterUIType.HeaderIcons; this.ultraGrid1.DisplayLayout.Override.FilterUIType = FilterUIType.HeaderIcons; this.dateTimePicker1.Value = System.DateTime.Now.AddDays(-7); this.DoQuery(); } private void ultraTabControl1_Click(object sender, EventArgs e) { if (this.ultraTabControl1.Tabs[1].Selected) //判定记录 { this.label6.Text = "判定时间"; } if (this.ultraTabControl1.Tabs[0].Selected) //判定记录 { this.label6.Text = "生产时间"; } } private void DoExport() { try { if (this.ultraGrid4.Rows.Count == 0) { MessageBox.Show("没有可以导出的数据", "提示"); return; } if (this.saveFileDialog1.ShowDialog(this) == DialogResult.OK) { string fName = this.saveFileDialog1.FileName; this.ultraGridExcelExporter1.Export(this.ultraGrid4, fName); Process.Start(fName); } } catch (Exception ex) { System.Diagnostics.Debug.WriteLine(ex.ToString()); } } } }