You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							689 lines
						
					
					
						
							39 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							689 lines
						
					
					
						
							39 KiB
						
					
					
				| using Newtonsoft.Json.Linq; | |
| using nGantt.GanttChart; | |
| using ScottPlot.Palettes; | |
| using SunlightCentralizedControlManagement_SCCM_.UserClass; | |
| using SunlightCentralizedControlManagement_SCCM_.ViewModel; | |
| using SunlightCentralizedControlManagement_SCCM_.WindowsView; | |
| using System; | |
| using System.Collections.Generic; | |
| using System.Data; | |
| using System.Data.SqlClient; | |
| using System.Linq; | |
| using System.Text; | |
| using System.Text.RegularExpressions; | |
| using System.Threading.Tasks; | |
| using System.Windows; | |
| using System.Windows.Controls; | |
| using System.Windows.Data; | |
| using System.Windows.Documents; | |
| using System.Windows.Input; | |
| using System.Windows.Media; | |
| using System.Windows.Media.Imaging; | |
| using System.Windows.Navigation; | |
| using System.Windows.Shapes; | |
| using System.Xml.Linq; | |
| using TouchSocket.Core; | |
| using static SunlightCentralizedControlManagement_SCCM_.UserClass.SqliteHelper; | |
| using static SunlightCentralizedControlManagement_SCCM_.WindowsView.ViewStep; | |
| using static System.Windows.Forms.AxHost; | |
| 
 | |
| namespace SunlightCentralizedControlManagement_SCCM_.View | |
| { | |
|     /// <summary> | |
|     /// ProductionPlanningEdit.xaml 的交互逻辑 | |
|     /// </summary> | |
|     public partial class DyeingPlanView : UserControl | |
|     {                   | |
|         DataTable ProgramName = new DataTable(); | |
|         DataTable WorkOrder =new DataTable(); | |
|         DataTable dat = new DataTable(); | |
|         DataTable TEMPTable = new DataTable(); | |
|         DataTable DyelotsBulkedRecipe=new DataTable(); | |
|         public string WorkOrder_n; | |
|         public DyeingPlanView() | |
|         { | |
|             InitializeComponent(); | |
|             ProgramName = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet("select * from ProgramName order by ProgramID desc", null).Tables[0];//缓存              | |
|             comboBoxMachine.ItemsSource = MainWindowViewModel.Machines.AsEnumerable().Select(rowdata => rowdata.Field<string>("name")).ToList();//转换机台                                                                                                                             | |
|             comboBoxProgram.ItemsSource = ProgramName.AsEnumerable().Select(rowdata => rowdata.Field<string>("ProgramName")).ToList();//转换工艺代码  | |
|             TEXTUSER.Text = MainWindow.user_; | |
| 
 | |
|             TEMPTable.Columns.Add("Time", Type.GetType("System.String")); | |
|             TEMPTable.Columns.Add("MST", Type.GetType("System.Double")); | |
|         } | |
|         private void UserControl_Loaded(object sender, RoutedEventArgs e) | |
|         { | |
|             | |
|         } | |
|         private void comboBoxMachine_DropDownClosed(object sender, EventArgs e)//机台选择 | |
|         { | |
|             string[] sArray = Regex.Split(comboBoxMachine.Text, @"\+", RegexOptions.IgnoreCase); | |
|             if (sArray.Length <= 1) | |
|             { | |
|                 comboBoxDyelot.IsEnabled = true; | |
|                 DataTable DatDyelot = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet("select * from Dyelot where Machine='" + comboBoxMachine.Text + "' and State='101' order by Dyelot desc", null).Tables[0];  //读取计划表写入缓存                                                                                                                                                                        | |
|                 comboBoxDyelot.ItemsSource = DatDyelot.AsEnumerable().Select(rowdata => rowdata.Field<string>("Dyelot")).ToList();//转换代码  | |
|             } | |
|         } | |
|         private void Button_Click(object sender, RoutedEventArgs e)//保存按钮 | |
|         { | |
|             if (string.IsNullOrEmpty(comboBoxMachine.Text)) | |
|             { | |
|                 MessageBox.Show("Not Machine", "SCCM", MessageBoxButton.OK, MessageBoxImage.Question); | |
|                 return; | |
|             } | |
|             if (string.IsNullOrEmpty(comboBoxProgram.Text)) | |
|             { | |
|                 MessageBox.Show("Not Program", "SCCM", MessageBoxButton.OK, MessageBoxImage.Question); | |
|                 return; | |
|             } | |
|             string[] pArray = Regex.Split(comboBoxProgram.Text, @"\+", RegexOptions.IgnoreCase); | |
| 
 | |
|             //单机器信息写入 | |
|             string sTime; | |
|             string StartTime_; | |
|             string WorkOrder_ = comboBoxMachine.Text + "_" + DateTime.Now.ToString("yyMMddHHmmss"); | |
|             if (!string.IsNullOrEmpty(comboBoxWorkOrder.Text)) WorkOrder_ = comboBoxWorkOrder.Text; | |
|             string ProgramName_ = comboBoxProgram.Text; | |
|             string ProgramID_ = null; | |
|             for (int j = 0; j < pArray.Length; j++) | |
|             { | |
|                 try | |
|                 { | |
|                     if (j == 0) | |
|                     { | |
|                         ProgramID_ = ProgramName.Select("ProgramName='" + pArray[j] + "'"). | |
|                        First().Field<object>("ProgramID").ToString(); | |
|                     } | |
|                     else | |
|                     { | |
|                         ProgramID_ = ProgramID_ + "+" + ProgramName.Select("ProgramName='" + pArray[j] + "'"). | |
|                         First().Field<object>("ProgramID").ToString(); | |
|                     } | |
|                 } | |
|                 catch (Exception) | |
|                 { | |
|                     MessageBox.Show("Not Program", "SCCM", MessageBoxButton.OK, MessageBoxImage.Question); | |
|                     return; | |
|                 } | |
|             } | |
|             string Machines_ = comboBoxMachine.Text; | |
|             string State_ = "100"; | |
|             string Dyelot_ = comboBoxDyelot.Text; | |
|             string color_ = color.Background.ToString(); | |
|             try | |
|             { | |
|                 sTime = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet( | |
|                     "select * from WorkOrder where Machines='" + comboBoxMachine.Text + "' order by EndTime desc", null). | |
|                     Tables[0].Select().First().Field<object>("EndTime").ToString();  //读取计划表写入缓存                   | |
|                 if (DateTime.Now < DateTime.Parse(sTime)) | |
|                 { | |
|                     StartTime_ = DateTime.Parse(sTime).AddMinutes(1).ToString("yyyy/MM/dd  HH:mm:ss"); | |
|                 } | |
|                 else | |
|                 { | |
|                     StartTime_ = DateTime.Now.AddMinutes(1).ToString("yyyy/MM/dd  HH:mm:ss"); | |
|                 } | |
|             } | |
|             catch (Exception) | |
|             { | |
|                 StartTime_ = DateTime.Now.AddMinutes(1).ToString("yyyy/MM/dd  HH:mm:ss"); | |
|             } | |
| 
 | |
|             string Time_ = "0:00"; | |
|             for (int k = 0; k < pArray.Length; k++) | |
|             { | |
|                 string t = ProgramName.Select("ProgramName='" + pArray[k] + "'"). | |
|                 First().Field<object>("Time").ToString(); | |
|                 Time_ = (DateTime.Parse(Time_) + DateTime.Parse(t).TimeOfDay).ToString("HH:mm:ss"); | |
|             } | |
|             string EndTime_ = (DateTime.Parse(StartTime_) + DateTime.Parse(Time_).TimeOfDay).ToString("yyyy/MM/dd  HH:mm:ss"); | |
| 
 | |
|             //插入数据信息 | |
|             Dictionary<string, object> WorkOrder_new = new Dictionary<string, object>();//缓存函数 | |
|             WorkOrder_new.Add("StartTime", StartTime_); | |
|             WorkOrder_new.Add("EndTime", EndTime_); | |
|             WorkOrder_new.Add("Time", Time_); | |
|             WorkOrder_new.Add("WorkOrder", WorkOrder_); | |
|             WorkOrder_new.Add("ProgramName", ProgramName_); | |
|             WorkOrder_new.Add("ProgramID", ProgramID_); | |
|             WorkOrder_new.Add("Machines", Machines_); | |
|             WorkOrder_new.Add("State", State_); | |
|             WorkOrder_new.Add("Dyelot", Dyelot_); | |
|             WorkOrder_new.Add("Remark", null); | |
|             WorkOrder_new.Add("lock", 0); | |
|             WorkOrder_new.Add("color", color_); | |
|             WorkOrder_new.Add("ColorNumber", TEXTColorNumber.Text); | |
|             WorkOrder_new.Add("Client", TEXTClient.Text); | |
|             WorkOrder_new.Add("ClothWeight", TEXTClothWeight.Text); | |
|             WorkOrder_new.Add("ClothSpecies", TEXTClothSpecies.Text); | |
|             WorkOrder_new.Add("BathRatio", TEXTBathRatio.Text); | |
|             WorkOrder_new.Add("Total", TEXTTotal.Text); | |
|             WorkOrder_new.Add("USER", TEXTUSER.Text); | |
|             WorkOrder_new.Add("ColorName", TEXTColorName.Text); | |
|             MainWindowViewModel.SQLiteHelpers.InsertData("WorkOrder", WorkOrder_new);// 执行插入 | |
|  | |
|             //插入信息 | |
|             Dictionary<string, object> WorkOrder_set = new Dictionary<string, object>();//缓存函数 | |
|             WorkOrder_set.Add("WorkOrder", WorkOrder_); | |
|             WorkOrder_set.Add("PumpSpeed", PumpSpeed.Text); | |
|             WorkOrder_set.Add("Blower", Blower.Text); | |
|             WorkOrder_set.Add("Swing", Swing.Text); | |
|             WorkOrder_set.Add("ClothWheel", ClothWheel.Text); | |
|             WorkOrder_set.Add("Nozzle", Nozzle.Text); | |
|             MainWindowViewModel.SQLiteHelpers.InsertData("WorkOrderSet", WorkOrder_set);// 执行插入 | |
|  | |
|             Dictionary<string, object> WorkOrder_DAT = new Dictionary<string, object>();//缓存函数 | |
|             for (int x = 0; x < dat.Rows.Count; x++) | |
|             { | |
|                 WorkOrder_DAT.Add("WorkOrder", WorkOrder_); | |
|                 WorkOrder_DAT.Add("Dyelot", Dyelot_); | |
|                 WorkOrder_DAT.Add("ProgramID", dat.Rows[x]["ProgramID"]); | |
|                 WorkOrder_DAT.Add("Program", dat.Rows[x]["Program"]); | |
|                 WorkOrder_DAT.Add("Step", dat.Rows[x]["Step"]); | |
|                 WorkOrder_DAT.Add("StepID", dat.Rows[x]["StepID"]); | |
|                 WorkOrder_DAT.Add("StepName", dat.Rows[x]["StepName"]); | |
|                 WorkOrder_DAT.Add("ParameterName", dat.Rows[x]["ParameterName"]); | |
|                 WorkOrder_DAT.Add("Parameter1", dat.Rows[x]["Parameter1"]); | |
|                 WorkOrder_DAT.Add("Parameter2", dat.Rows[x]["Parameter2"]); | |
|                 WorkOrder_DAT.Add("Parameter3", dat.Rows[x]["Parameter3"]); | |
|                 WorkOrder_DAT.Add("Parameter4", dat.Rows[x]["Parameter4"]); | |
|                 WorkOrder_DAT.Add("Parameter5", dat.Rows[x]["Parameter5"]); | |
|                 WorkOrder_DAT.Add("Parameter6", dat.Rows[x]["Parameter6"]); | |
|                 WorkOrder_DAT.Add("Parameter7", dat.Rows[x]["Parameter7"]); | |
|                 WorkOrder_DAT.Add("Parameter8", dat.Rows[x]["Parameter8"]); | |
|                 WorkOrder_DAT.Add("Parameter9", dat.Rows[x]["Parameter9"]); | |
|                 WorkOrder_DAT.Add("Parameter10", dat.Rows[x]["Parameter10"]); | |
|                 MainWindowViewModel.SQLiteHelpers.InsertData("WorkorderSteps", WorkOrder_DAT);//行插入                                                                              | |
|                 WorkOrder_DAT.Clear(); | |
|             } | |
|             if (!String.IsNullOrEmpty(comboBoxDyelot.Text))//料单信息 | |
|             { | |
|                 for (int x = 0; x < DyelotsBulkedRecipe.Rows.Count; x++) | |
|                 { | |
|                     WorkOrder_DAT.Add("WorkOrder", comboBoxWorkOrder.Text); | |
|                     WorkOrder_DAT.Add("Dyelot", DyelotsBulkedRecipe.Rows[x]["Dyelot"]); | |
|                     WorkOrder_DAT.Add("Redye", DyelotsBulkedRecipe.Rows[x]["Redye"]); | |
|                     WorkOrder_DAT.Add("Step", DyelotsBulkedRecipe.Rows[x]["StepNumber"]); | |
|                     WorkOrder_DAT.Add("TIME", DyelotsBulkedRecipe.Rows[x]["Created"]); | |
|                     WorkOrder_DAT.Add("Tank", DyelotsBulkedRecipe.Rows[x]["TankNo"]); | |
|                     WorkOrder_DAT.Add("State", DyelotsBulkedRecipe.Rows[x]["DispenseResult"]); | |
|                     WorkOrder_DAT.Add("Machine", comboBoxMachine.Text); | |
|                     WorkOrder_DAT.Add("ProductCode", DyelotsBulkedRecipe.Rows[x]["ProductCode"]); | |
|                     WorkOrder_DAT.Add("ProductName", DyelotsBulkedRecipe.Rows[x]["ProductName"]); | |
|                     WorkOrder_DAT.Add("ProductType", DyelotsBulkedRecipe.Rows[x]["ProductType"]); | |
|                     WorkOrder_DAT.Add("Grams", DyelotsBulkedRecipe.Rows[x]["Grams"]); | |
|                     WorkOrder_DAT.Add("Amount", DyelotsBulkedRecipe.Rows[x]["Amount"]); | |
|                     WorkOrder_DAT.Add("DispenseStartTime", DyelotsBulkedRecipe.Rows[x]["DispenseStartTime"]); | |
|                     WorkOrder_DAT.Add("DispenseEndTime", DyelotsBulkedRecipe.Rows[x]["DispenseEndTime"]); | |
|                     WorkOrder_DAT.Add("DispenseGrams", DyelotsBulkedRecipe.Rows[x]["DispenseGrams"]); | |
|                     WorkOrder_DAT.Add("Dispense", DyelotsBulkedRecipe.Rows[x]["Dispenser"]); | |
|                     WorkOrder_DAT.Add("UserAccount", DyelotsBulkedRecipe.Rows[x]["UserAccount"]); | |
|                     MainWindowViewModel.SQLiteHelpers.InsertData("Dyelot", WorkOrder_DAT);//行插入                                                                              | |
|                     WorkOrder_DAT.Clear(); | |
|                 } | |
|             } | |
| 
 | |
|             LogGing.ExchangeDATA("Dyelot=" + comboBoxWorkOrder.Text + ";Machine=" + comboBoxMachine.Text + | |
|                 ";Program=" + comboBoxProgram.Text + ";User=" + TEXTUSER.Text + ";"); | |
| 
 | |
|             this.Visibility = Visibility.Collapsed; | |
|             ProductionPlanningView.UI = true; | |
|         } | |
|         private void Button_Quit(object sender, RoutedEventArgs e)//退出 | |
|         { | |
|             this.Visibility = Visibility.Collapsed; | |
|         } | |
|         public void DatSteps(DataTable db)//行号刷新 | |
|         { | |
|             int a = db.Rows.Count; | |
|             for (int i = 0; i < a; i++) | |
|             { | |
|                 DataRow dr = db.Rows[i]; | |
|                 dr.BeginEdit(); | |
|                 dr["Step"] = i + 1; | |
|                 dr.EndEdit(); | |
|             } | |
|         } | |
|         private void comboBoxProgram_DropDownClosed(object sender, EventArgs e)//工艺选择事件 | |
|         { | |
|             if (!string.IsNullOrEmpty(comboBoxProgram.Text)) | |
|             { | |
|                 dat.Clear(); | |
|                 dat = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet( | |
|                     "select * from ProgramSteps where Program='" + comboBoxProgram.SelectedValue + "' order by Step asc", null).Tables[0];  //读取计划表写入缓存 | |
|                 DatSteps(dat); | |
|                 Grid_data.ItemsSource = dat.DefaultView; | |
|             } | |
|         } | |
|         private void comboBoxProgram_TextChanged(object sender, TextChangedEventArgs e) | |
|         { | |
|             dat.Clear(); | |
|             string text = comboBoxProgram.Text; | |
|             if (!string.IsNullOrEmpty(text)) | |
|             {            | |
|                 try | |
|                 {  | |
|                     string[] sArray = Regex.Split(text, @"\+", RegexOptions.IgnoreCase); | |
|                   /*  if (!string.IsNullOrEmpty(WorkOrder_n)) | |
|                     { | |
|                         dat = SQLiteHelpers.ExecuteDataSet( | |
|                             "select * from WorkorderSteps where WorkOrder='" + WorkOrder_n + "' order by Step asc", null).Tables[0];  //读取计划表写入缓存 | |
|                     }//插入工单不为空时载入细节信息*/ | |
|                     for (int i = 0; i < sArray.Length; i++) | |
|                     { | |
|                         DataTable temp = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet( | |
|                             "select * from ProgramSteps where Program='" + sArray[i] + "' order by Step asc", null).Tables[0];  //读取计划表写入缓存 | |
|                         if (dat.Columns.Count == 0) dat = temp.Clone(); | |
|                         foreach (DataRow drT in temp.Rows) | |
|                         { | |
|                             dat.Rows.Add(drT.ItemArray); | |
|                         } | |
|                     }//以工艺名组合工艺细节 | |
|                     | |
|                     DatSteps(dat); | |
|                     Grid_data.ItemsSource = dat.DefaultView; | |
| 
 | |
|                     TEMP(); | |
|                 } | |
|                 catch (Exception) { } | |
|             } | |
| 
 | |
|         }//工艺修改事件 | |
|  | |
|         string Numder = null; | |
|         string ID = null; | |
|         string P1, P2, P3, P4, P5; | |
| 
 | |
|         private void MenuItem_edit(object sender, RoutedEventArgs e) | |
|         { | |
|             int rownum = Grid_data.SelectedIndex;//获取鼠标选中行并定义变量 | |
|             if (rownum != -1)//判断鼠标定位是否有效 | |
|             { | |
|                 ID = (Grid_data.Columns[2].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第0列, | |
|                 Numder = (Grid_data.Columns[3].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第1列, | |
|                 P1 = (Grid_data.Columns[6].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第6列, | |
|                 P2 = (Grid_data.Columns[7].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第7列, | |
|                 P3 = (Grid_data.Columns[8].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第8列, | |
|                 P4 = (Grid_data.Columns[9].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第9列, | |
|                 P5 = (Grid_data.Columns[10].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第10列, | |
|  | |
|                 if (string.IsNullOrEmpty(Numder)) { Numder = null; P1 = "0"; P2 = "0"; P3 = "0"; P4 = "0"; P5 = "0"; } | |
|                 if (ID == null) ID = dat.Rows.Count.ToString(); | |
|                 ViewStep viewstop = new ViewStep(Numder, dat.Select("STEP = " + ID).First()); | |
|                 viewstop.AddressUpdated += new ViewStep.AddressUpdateHandler(Address_ButtonClicked); | |
|                 viewstop.data = ID; | |
|                 viewstop.ShowDialog(); | |
|             } | |
|         } | |
|         private void MenuItem_Insert(object sender, RoutedEventArgs e)//右键插入 | |
|         { | |
|             int rownum = Grid_data.SelectedIndex;//获取鼠标选中行并定义变量 | |
|             if (rownum != -1)//判断鼠标定位是否有效 | |
|             { | |
|                 ID = (Grid_data.Columns[2].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位列, | |
|  | |
|                 int d = 0; | |
|                 if (ID != null) { d = Convert.ToInt32(ID); } else { return; } | |
|                 string ProgramID = dat.Select().First().Field<string>("ProgramID").ToString(); | |
|                 string ProgramNAME = dat.Select().First().Field<string>("Program").ToString(); | |
|                 DataRow dr = dat.NewRow();//添加表数据 | |
|                 dr["ProgramID"] = ProgramID; | |
|                 dr["Program"] = ProgramNAME; | |
|                 dat.Rows.InsertAt(dr, d - 1); | |
| 
 | |
|                 DatSteps(dat); | |
|                 Grid_data.ItemsSource = dat.DefaultView; | |
| 
 | |
|                 if (string.IsNullOrEmpty(Numder)) { Numder = null; P1 = "0"; P2 = "0"; P3 = "0"; P4 = "0"; P5 = "0"; } | |
|                 if (ID == null) ID = dat.Rows.Count.ToString(); | |
|                 ViewStep viewstop = new ViewStep(Numder, dat.Select("STEP = " + ID).First()); | |
|                 viewstop.AddressUpdated += new ViewStep.AddressUpdateHandler(Address_ButtonClicked); | |
|                 viewstop.data = ID; | |
|                 viewstop.ShowDialog(); | |
|             } | |
|         } | |
|         private void MenuItem_Delete(object sender, RoutedEventArgs e)//右键删除 | |
|         { | |
|             int rownum = Grid_data.SelectedIndex;//获取鼠标选中行并定义变量 | |
|             if (rownum != -1)//判断鼠标定位是否有效 | |
|             { | |
|                 ID = (Grid_data.Columns[2].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第0列,    | |
|                 dat.Rows.RemoveAt( Convert.ToInt32(ID)-1);                | |
|                     | |
|                 DatSteps(dat); | |
|                 Grid_data.ItemsSource = dat.DefaultView; | |
|             } | |
|         } | |
|         private void Grid_data_MouseDoubleClick(object sender, MouseButtonEventArgs e) | |
|         { | |
|             int rownum = Grid_data.SelectedIndex;//获取鼠标选中行并定义变量 | |
|             if (rownum != -1)//判断鼠标定位是否有效 | |
|             { | |
|                 ID = (Grid_data.Columns[2].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第0列, | |
|                 Numder = (Grid_data.Columns[3].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第1列, | |
|                 P1 = (Grid_data.Columns[6].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第6列, | |
|                 P2 = (Grid_data.Columns[7].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第7列, | |
|                 P3 = (Grid_data.Columns[8].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第8列, | |
|                 P4 = (Grid_data.Columns[9].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第9列, | |
|                 P5 = (Grid_data.Columns[10].GetCellContent(Grid_data.Items[rownum]) as TextBlock).Text;//定位第10列, | |
|  | |
|                 if (string.IsNullOrEmpty(Numder)) { Numder = null; P1 = "0"; P2 = "0"; P3 = "0"; P4 = "0"; P5 = "0"; } | |
|                 if (ID == null) ID = dat.Rows.Count.ToString(); | |
|                 ViewStep viewstop = new ViewStep(Numder, dat.Select("STEP = " + ID).First()); | |
|                 viewstop.AddressUpdated += new ViewStep.AddressUpdateHandler(Address_ButtonClicked); | |
|                 viewstop.data = ID; | |
|                 viewstop.ShowDialog(); | |
|             } | |
|         } | |
|         private void Address_ButtonClicked(object sender, AddressUpdateEventArgs e)//编辑返回结果 | |
|         { | |
|             int n = Convert.ToInt16(ID); | |
|             ID = null; | |
|             if (e.PNAME != "") | |
|             { | |
|                 DataRow dr = dat.Rows[n - 1]; | |
|                 dr.BeginEdit(); | |
|                 dr["StepID"] = e.StepID; | |
|                 dr["StepName"] = e.StepNAME; | |
|                 dr["ParameterName"] = e.PNAME; | |
|                 dr["Parameter1"] = e.Row_DAT.Field<double>("Parameter1"); | |
|                 dr["Parameter2"] = e.Row_DAT.Field<double>("Parameter1"); | |
|                 dr["Parameter3"] = e.Row_DAT.Field<double>("Parameter1"); | |
|                 dr["Parameter4"] = e.Row_DAT.Field<double>("Parameter1"); | |
|                 dr["Parameter5"] = e.Row_DAT.Field<double>("Parameter1"); | |
|                 dr["Parameter1_S1"] = e.Row_DAT.Field<double>("Parameter1_S1"); | |
|                 dr["Parameter2_S1"] = e.Row_DAT.Field<double>("Parameter2_S1"); | |
|                 dr["Parameter3_S1"] = e.Row_DAT.Field<double>("Parameter3_S1"); | |
|                 dr["Parameter4_S1"] = e.Row_DAT.Field<double>("Parameter4_S1"); | |
|                 dr["Parameter5_S1"] = e.Row_DAT.Field<double>("Parameter5_S1"); | |
|                 dr["Parameter1_S2"] = e.Row_DAT.Field<double>("Parameter1_S2"); | |
|                 dr["Parameter2_S2"] = e.Row_DAT.Field<double>("Parameter2_S2"); | |
|                 dr["Parameter3_S2"] = e.Row_DAT.Field<double>("Parameter3_S2"); | |
|                 dr["Parameter4_S2"] = e.Row_DAT.Field<double>("Parameter4_S2"); | |
|                 dr["Parameter5_S2"] = e.Row_DAT.Field<double>("Parameter5_S2"); | |
|                 dr["Parameter1_S3"] = e.Row_DAT.Field<double>("Parameter1_S3"); | |
|                 dr["Parameter2_S3"] = e.Row_DAT.Field<double>("Parameter2_S3"); | |
|                 dr["Parameter3_S3"] = e.Row_DAT.Field<double>("Parameter3_S3"); | |
|                 dr["Parameter4_S3"] = e.Row_DAT.Field<double>("Parameter4_S3"); | |
|                 dr["Parameter5_S3"] = e.Row_DAT.Field<double>("Parameter5_S3"); | |
|                 dr["StepName_S1"] = e.Row_DAT.Field<string>("StepName_S1"); | |
|                 dr["StepName_S2"] = e.Row_DAT.Field<string>("StepName_S2"); | |
|                 dr["StepName_S3"] = e.Row_DAT.Field<string>("StepName_S3"); | |
|                 dr["StepID_S1"] = e.Row_DAT.Field<string>("StepID_S1"); | |
|                 dr["StepID_S2"] = e.Row_DAT.Field<string>("StepID_S2"); | |
|                 dr["StepID_S3"] = e.Row_DAT.Field<string>("StepID_S3"); | |
|                 dr.EndEdit(); | |
|                 Grid_data.SelectedIndex = -1; | |
|             } | |
|             else | |
|             { | |
|                 MainWindowViewModel.dt_TP.Rows.RemoveAt(n - 1); | |
|                 DatSteps(dat); | |
|                 Grid_data.SelectedIndex = -1; | |
|             } | |
|             Grid_data.ItemsSource = dat.DefaultView; | |
|         } | |
|         private void TEMP()  | |
|         { | |
|             //处理计划温度图表 | |
|             TEMPTable.Clear(); | |
|              | |
|             string TIMET = "00:00:00"; | |
|             Double MSTT = 30.0; | |
|             Double TT; | |
|             Double TC; | |
|             TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|             for (int i = 0; i < dat.Rows.Count; i++) | |
|             { | |
|                 switch (dat.Rows[i][3].ToString())//步骤用时计算 | |
|                 { | |
|                     case "001": | |
|                         TT = MSTT; | |
|                         TC = (Double)dat.Rows[i][7]; | |
|                         if (TC > 9.9 || TC < 0.1) TC = 9.9;//计算限制 | |
|                         MSTT = (Double)dat.Rows[i][6]; | |
|                         TT = Math.Abs(MSTT - TT) / TC * 60; | |
|                         TIMET = Convert.ToDateTime(TIMET).AddSeconds(TT).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((Double)dat.Rows[i][8]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "007": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes(5).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "008": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes(5).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "013": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((Double)dat.Rows[i][8]* (Double)dat.Rows[i][9]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "015": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((Double)dat.Rows[i][8]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "017": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((Double)dat.Rows[i][8]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "020": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes(5).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "022": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes(5).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "031": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((int)dat.Rows[i][6]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "065": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((int)dat.Rows[i][8]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "091": | |
|                         TT = MSTT; | |
|                         TC = (Double)dat.Rows[i][7]; | |
|                         if (TC > 9.9 || TC < 0.1) TC = 9.9;//计算限制 | |
|                         MSTT = (Double)dat.Rows[i][6]; | |
|                         TT = Math.Abs(MSTT - TT) / TC * 60; | |
|                         TIMET = Convert.ToDateTime(TIMET).AddSeconds(TT).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     case "093": | |
|                         TIMET = Convert.ToDateTime(TIMET).AddMinutes((int)dat.Rows[i][6]).ToString("HH:mm:ss"); | |
|                         TEMPTable.Rows.Add(new object[] { TIMET, MSTT }); | |
|                         break; | |
|                     default: | |
|                         break; | |
|                 } | |
|             } | |
|             Picture.Content = new View.CurveTemp(TEMPTable); | |
|         } //计划温度图表 | |
|         private async void comboBoxWorkOrder_KeyDown(object sender, KeyEventArgs e)//工单输入 | |
|         { | |
|             if (e.Key == Key.Enter && MainWindowViewModel.DyelotsDispenser) | |
|             { | |
|                 int dat_c = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet("select * from WorkOrder where WorkOrder = '" + comboBoxWorkOrder.Text + "'", null).Tables[0].Rows.Count;//缓存              | |
|  | |
|                 if (dat_c > 0)//查询料单是否可用 | |
|                 { | |
|                     comboBoxWorkOrder.Text = null; | |
|                     MessageBox.Show(Properties.Resources.TTAE, "WorkOrder", MessageBoxButton.OK, MessageBoxImage.Information); //连接成功提示是否保存 | |
|                     return; | |
|                 } | |
| 
 | |
|                 string Connstr_SC; | |
|                 string DYELOTS_sql = "SELECT * FROM [dbo].[DYELOTS] WHERE Dyelot = '" + comboBoxWorkOrder.Text + "'";//单号查询语句                                                                                                                              | |
|                 string DyelotsBulkedRecipe_sql = "SELECT * FROM [dbo].[DyelotsBulkedRecipe] WHERE Dyelot = '" + comboBoxWorkOrder.Text + "'";                                                                                                                            | |
|                 try | |
|                 { | |
|                     if (MainWindowViewModel.SQMOD == "Windows Authentication") | |
|                     { | |
|                         Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";Trusted_Connection=SSPI"; | |
|                     } | |
|                     else | |
|                     { | |
|                         Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";User ID=" + MainWindowViewModel.SQLUSER + ";Password=" + MainWindowViewModel.SQLPASWORD; | |
|                     } | |
|                     SqlConnection conn_SC = new SqlConnection(Connstr_SC); | |
|                     await conn_SC.OpenAsync();     //连接数据库 | |
|                     SqlDataAdapter DYELOTS_data = new SqlDataAdapter(DYELOTS_sql, Connstr_SC);   //查询 | |
|                     SqlDataAdapter DyelotsBulkedRecipe_ = new SqlDataAdapter(DyelotsBulkedRecipe_sql, Connstr_SC);   | |
|                     conn_SC.Close(); | |
|                     DyelotsBulkedRecipe_.Fill(DyelotsBulkedRecipe); | |
| 
 | |
|                     DataTable ds = new DataTable();//载入信息 | |
|                     DYELOTS_data.Fill(ds); | |
|                     TEXTColorNumber.Text = ds.AsEnumerable().Select(row => row.Field<string>("ColorNo")).First(); | |
|                     TEXTColorName.Text = ds.AsEnumerable().Select(row => row.Field<string>("ColorName")).First(); | |
|                     TEXTClient.Text = ds.AsEnumerable().Select(row => row.Field<string>("CustomerName")).First(); | |
|                     TEXTClothSpecies.Text = ds.AsEnumerable().Select(row => row.Field<string>("FabricName")).First(); | |
|                     TEXTClothWeight.Text = ds.AsEnumerable().Select(row => row.Field<Double>("TotalWeight")).First().ToString(); | |
|                     TEXTBathRatio.Text = ds.AsEnumerable().Select(row => row.Field<string>("LiquidRatio")).First(); | |
|                     TEXTTotal.Text = ds.AsEnumerable().Select(row => row.Field<string>("TotalVolume")).First(); | |
|                     comboBoxDyelot.Text = ds.AsEnumerable().Select(row => row.Field<string>("Dyelot")).First(); | |
| 
 | |
|                     string machine_ = ds.AsEnumerable().Select(row => row.Field<string>("Machine")).First();//机台 | |
|                     if (MainWindowViewModel.Machines.Select("Name ='"+machine_+"'").Length == 0)  | |
|                     { | |
|                         comboBoxMachine.Text = null; | |
|                     } | |
|                     else | |
|                     { | |
|                         comboBoxMachine.Text = machine_; | |
|                     } | |
|                     string user_ = ds.AsEnumerable().Select(row => row.Field<string>("UserAccount")).First();//用户名 | |
|                     if (!String.IsNullOrEmpty(user_)) TEXTUSER.Text = user_; | |
|                     comboBoxProgram.Text = ds.AsEnumerable().Select(row => row.Field<string>("Program")).First(); | |
| 
 | |
|                     if (ds.AsEnumerable().Select(row => row.Field<int>("color")).First() > 0)//颜色 | |
|                     { | |
|                         string colorValue = string.Format("{0:X6}", ds.AsEnumerable().Select(row => row.Field<int>("color")).First());//十进制RGB数值转十六进制六位RGB并补0位例“C0C0C0”              | |
|                         color.Background = new SolidColorBrush((Color)ColorConverter.ConvertFromString( | |
|                             "#FF" + colorValue.Substring(4, 2) + colorValue.Substring(2, 2) + colorValue.Substring(0, 2))); | |
|                     }                     | |
|                 } | |
|                 catch (Exception ex) | |
|                 { | |
|                     LogGing.ERRDATA(ex); | |
|                 } | |
|             } | |
|         } | |
|         private async void comboBoxDyelot_KeyDown(object sender, KeyEventArgs e)//料单输入 | |
|         { | |
|             if (e.Key == Key.Enter && MainWindowViewModel.DyelotsDispenser) | |
|             { | |
|                 string Connstr_SC; | |
|                 string DYELOTS_sql = "SELECT * FROM [dbo].[DYELOTS] WHERE Dyelot = '" + comboBoxDyelot.Text + "'";//单号查询语句                                                                                                                              | |
|                 try | |
|                 { | |
|                     int dat_c = MainWindowViewModel.SQLiteHelpers.ExecuteDataSet("select * from Dyelot where Dyelot = '" + comboBoxDyelot.Text + "'", null).Tables[0].Rows.Count;//缓存              | |
|  | |
|                     if (dat_c > 0)//查询料单是否可用 | |
|                     { | |
|                         comboBoxDyelot.Text = null; | |
|                         MessageBox.Show(Properties.Resources.TPLHBU, "Dyelot", MessageBoxButton.OK, MessageBoxImage.Information); //连接成功提示是否保存 | |
|                         return; | |
|                     } | |
| 
 | |
|                     if (MainWindowViewModel.SQMOD == "Windows Authentication") | |
|                     { | |
|                         Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";Trusted_Connection=SSPI"; | |
|                     } | |
|                     else | |
|                     { | |
|                         Connstr_SC = "server=" + MainWindowViewModel.SQLIP + ";database=" + MainWindowViewModel.SQLNAME + ";User ID=" + MainWindowViewModel.SQLUSER + ";Password=" + MainWindowViewModel.SQLPASWORD; | |
|                     } | |
|                     SqlConnection conn_SC = new SqlConnection(Connstr_SC); | |
|                     await conn_SC.OpenAsync();     //连接数据库 | |
|                     SqlDataAdapter DYELOTS_data = new SqlDataAdapter(DYELOTS_sql, Connstr_SC);   //查询 | |
|                     conn_SC.Close(); | |
| 
 | |
|                     DataTable ds = new DataTable();//载入信息 | |
|                     DYELOTS_data.Fill(ds); | |
|                     TEXTColorNumber.Text = ds.AsEnumerable().Select(row => row.Field<string>("ColorNo")).First(); | |
|                     TEXTColorName.Text = ds.AsEnumerable().Select(row => row.Field<string>("ColorName")).First(); | |
|                     TEXTClient.Text = ds.AsEnumerable().Select(row => row.Field<string>("CustomerName")).First(); | |
|                     TEXTClothSpecies.Text = ds.AsEnumerable().Select(row => row.Field<string>("FabricName")).First(); | |
|                     TEXTClothWeight.Text = ds.AsEnumerable().Select(row => row.Field<Double>("TotalWeight")).First().ToString(); | |
|                     TEXTBathRatio.Text = ds.AsEnumerable().Select(row => row.Field<string>("LiquidRatio")).First(); | |
|                     TEXTTotal.Text = ds.AsEnumerable().Select(row => row.Field<string>("TotalVolume")).First(); | |
|                    // comboBoxDyelot.Text = ds.AsEnumerable().Select(row => row.Field<string>("Dyelot")).First(); | |
|  | |
|                     string machine_ = ds.AsEnumerable().Select(row => row.Field<string>("Machine")).First();//机台 | |
|                     if (MainWindowViewModel.Machines.Select("Name ='" + machine_ + "'").Length == 0) | |
|                     { | |
|                         comboBoxMachine.Text = null; | |
|                     } | |
|                     else | |
|                     { | |
|                         comboBoxMachine.Text = machine_; | |
|                     } | |
|                     string user_ = ds.AsEnumerable().Select(row => row.Field<string>("UserAccount")).First();//用户名 | |
|                     if (!String.IsNullOrEmpty(user_)) TEXTUSER.Text = user_; | |
|                     comboBoxProgram.Text = ds.AsEnumerable().Select(row => row.Field<string>("Program")).First(); | |
| 
 | |
|                     if (ds.AsEnumerable().Select(row => row.Field<int>("color")).First() > 0)//颜色 | |
|                     { | |
|                         string colorValue = string.Format("{0:X6}", ds.AsEnumerable().Select(row => row.Field<int>("color")).First());//十进制RGB数值转十六进制六位RGB并补0位例“C0C0C0”              | |
|                         color.Background = new SolidColorBrush((Color)ColorConverter.ConvertFromString( | |
|                             "#FF" + colorValue.Substring(4, 2) + colorValue.Substring(2, 2) + colorValue.Substring(0, 2))); | |
|                     } | |
|                 } | |
|                 catch (Exception ex) | |
|                 { | |
|                     LogGing.ERRDATA(ex); | |
|                 } | |
|             } | |
| 
 | |
|         } | |
|         private void Tb_KeyTEXTClothWeight(object sender, TextCompositionEventArgs e)//输入事件 | |
|         { | |
|             Regex numbeRegex = new Regex("^[.][0-9]+$|^[0-9]*[.]{0,1}[0-9]*$"); | |
|             e.Handled = | |
|                 !numbeRegex.IsMatch( | |
|                     TEXTClothWeight.Text.Insert( | |
|                         TEXTClothWeight.SelectionStart, e.Text)); | |
|             TEXTClothWeight.Text = TEXTClothWeight.Text.Trim(); | |
|         } | |
|         private void Tb_KeyTEXTBathRatio(object sender, TextCompositionEventArgs e)//输入事件 | |
|         { | |
|             Regex numbeRegex = new Regex("^[.][0-9]+$|^[0-9]*[.]{0,1}[0-9]*$"); | |
|             e.Handled = | |
|                 !numbeRegex.IsMatch( | |
|                     TEXTBathRatio.Text.Insert( | |
|                         TEXTBathRatio.SelectionStart, e.Text)); | |
|             TEXTBathRatio.Text = TEXTBathRatio.Text.Trim(); | |
|         } | |
|         private void Tb_KeyTEXTTotal(object sender, TextCompositionEventArgs e)//输入事件 | |
|         { | |
|             Regex numbeRegex = new Regex("^[.][0-9]+$|^[0-9]*[.]{0,1}[0-9]*$"); | |
|             e.Handled = | |
|                 !numbeRegex.IsMatch( | |
|                     TEXTTotal.Text.Insert( | |
|                         TEXTTotal.SelectionStart, e.Text)); | |
|             TEXTTotal.Text = TEXTTotal.Text.Trim(); | |
|         } | |
|         private void color_color_MouseDoubleClick(object sender, MouseButtonEventArgs e)//颜色 | |
|         { | |
|             System.Windows.Forms.ColorDialog colorDialog = new System.Windows.Forms.ColorDialog();//使用调色盘控件ColorDialog | |
|             if (colorDialog.ShowDialog() == System.Windows.Forms.DialogResult.OK)//打开调色盘 | |
|             { | |
| 
 | |
|                 System.Drawing.Color DColor = colorDialog.Color;////获取选中色彩信息 | |
|                 //System.Windows.Media.Color MColor = new System.Windows.Media.Color();//转换 | |
|                 System.Windows.Media.Color MColor = System.Windows.Media.Color.FromArgb(DColor.A, DColor.R, DColor.G, DColor.B);//转换并配置ARGB参数 | |
|                 color.Background = new SolidColorBrush(MColor);//ARGB参数输出至Color的背景色 | |
|                 //string colorCode = string.Format("{0:X2}", DColor.B) + string.Format("{0:X2}", DColor.G) + string.Format("{0:X2}", DColor.R);//反向十六进制RGB | |
|                 //string colorCode = string.Format("{0:X2}", DColor.R) + string.Format("{0:X2}", DColor.G) + string.Format("{0:X2}", DColor.B);//正向十六进制RGB | |
|                 //ColorCode_SQL = Convert.ToInt32(colorCode, 16);//十六进制RGB转存储数值 | |
|  | |
|             } | |
|         } | |
|     } | |
| }
 | |
| 
 |