diff --git a/View/EquipmentSimulationView.xaml b/View/EquipmentSimulationView.xaml
index cbef8f6..c99af62 100644
--- a/View/EquipmentSimulationView.xaml
+++ b/View/EquipmentSimulationView.xaml
@@ -5,6 +5,8 @@
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:local="clr-namespace:DyeingComputer.View"
mc:Ignorable="d"
- d:DesignHeight="630" d:DesignWidth="1280" VerticalAlignment="Top">
-
+ d:DesignHeight="630" d:DesignWidth="1280">
+
+
+
diff --git a/View/WorkOrderView.xaml.cs b/View/WorkOrderView.xaml.cs
index fa32de0..1006667 100644
--- a/View/WorkOrderView.xaml.cs
+++ b/View/WorkOrderView.xaml.cs
@@ -205,6 +205,7 @@ namespace DyeingComputer.View
{
MainWindowViewModel.WorkNumder = WorkOrder_Numder;
TechnologicalProcessView.workName = Process_id;
+ MainWindowViewModel.SYS_REDYE = 0;
MainWindowViewModel.ViewID = 1;
var _mainWindow = Application.Current.Windows.Cast().FirstOrDefault(window => window is MainWindow) as MainWindow;//跨页面
diff --git a/ViewModel/MainWindowViewModel.cs b/ViewModel/MainWindowViewModel.cs
index e257eab..0fe15b8 100644
--- a/ViewModel/MainWindowViewModel.cs
+++ b/ViewModel/MainWindowViewModel.cs
@@ -25,6 +25,7 @@ using Microsoft.Win32;
using static DyeingComputer.Windows.ViewStep;
using System.Windows.Media;
using System.Runtime.Remoting.Channels;
+using System.Diagnostics.Eventing.Reader;
namespace DyeingComputer.ViewModel
@@ -61,6 +62,7 @@ namespace DyeingComputer.ViewModel
private PID pid = new PID();
public static DataTable RUN_DATATABLE = new DataTable();//缓存工作表
public static int RUN_STEPID;//当前步骤
+ public static int SYS_REDYE=0;//当前重燃步
public MainWindowViewModel()
{
@@ -112,6 +114,7 @@ namespace DyeingComputer.ViewModel
private int MT40;//低水位
private int MT41;//安全水位
private static int MU01;//呼叫操作员
+ private string S01;//机台号
private int S16;//机型
public static int SM01;//副缸
public static int SM02;//副缸
@@ -120,6 +123,9 @@ namespace DyeingComputer.ViewModel
private double MS01;//1缸温度偏差
private double MS02;//2缸温度偏差
private double MS03;//3缸温度偏差
+ public int MS17;//副缸
+ public int MS18;//副缸
+ public int MS19;//副缸
void SYS_SET()
{
SQLiteHelpers = new SQLiteHelper(DBAddress); //数据库连接路径
@@ -149,7 +155,11 @@ namespace DyeingComputer.ViewModel
MS01 = Convert.ToDouble(Selet_con("MS01"));
MS02 = Convert.ToDouble(Selet_con("MS02"));
MS03 = Convert.ToDouble(Selet_con("MS03"));
+ MS17 = Convert.ToInt16(Selet_con("MS17"));
+ MS18 = Convert.ToInt16(Selet_con("MS18"));
+ MS19 = Convert.ToInt16(Selet_con("MS19"));
+ S01 = Selet_sys("S01");//
S16 = Convert.ToInt16(Selet_sys("S16"));//工作信息
SM01 = Convert.ToInt16(Selet_sys("SM01"));//FG
SM02 = Convert.ToInt16(Selet_sys("SM02"));//FG
@@ -412,10 +422,17 @@ namespace DyeingComputer.ViewModel
STEP_finish = false;
break;
case "050":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//主缸加压
case "051":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ SETP_runtime = true;
+ STEP_finish = false;
break;//主缸减压
case "054":
STEP_P1 = Convert.ToDouble(P1);
@@ -437,28 +454,66 @@ namespace DyeingComputer.ViewModel
STEP_finish = false;
break;//主泵停止
case "064":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ STEP_P3 = Convert.ToDouble(P3);
+ STEP_P4 = Convert.ToDouble(P4);
+ STEP_P5 = Convert.ToDouble(P5);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//药缸备药
case "065":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ STEP_P3 = Convert.ToDouble(P3);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//药缸加药
case "066":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ STEP_P3 = Convert.ToDouble(P3);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//呼叫输送
case "067":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ STEP_P3 = Convert.ToDouble(P3);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//呼叫输送
case "090":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//快速加酸
case "091":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ STEP_P3 = Convert.ToDouble(P3);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//PH温度控制
case "093":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//PH检测
case "094":
-
+ STEP_P1 = Convert.ToDouble(P1);
+ STEP_P2 = Convert.ToDouble(P2);
+ WORK_RUN = 2;
+ SETP_runtime = true;
+ STEP_finish = false;
break;//PH控制
default:
break;
@@ -467,6 +522,9 @@ namespace DyeingComputer.ViewModel
TimeSpan ts = new TimeSpan(00,00,01);//1秒间隔
private int temp_time10s = 10;//开关周期时间
+ private string TANK1, TANK2, TANK3;//料桶信息
+ public static string TANK1_DYELOT, TANK2_DYELOT, TANK3_DYELOT;//料单号
+ private int TANK1_REDYE,TANK1_STEP, TANK2_REDYE, TANK2_STEP, TANK3_REDYE, TANK3_STEP;
void STEP_RUN()
{
if (WORK_RUN == 2)
@@ -928,19 +986,213 @@ namespace DyeingComputer.ViewModel
Updata_dtd("3011", false);//主泵
if (S16 == 1) Updata_dtd("3012", false);//风机
STEP_finish = true;
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.PumpStops;
break;//主泵停止
case "064":
+ if ((STEP_P1 == 1)||(STEP_P1==0))
+ {
+ if (Selet_dtm("1017") >= STEP_P3)//水位
+ {
+ TANK1 = Resources.Ready;
+ Updata_dtd("3036", false);
+ Updata_dtd("3037", false);
+ Updata_dtd("3038", false);
+
+ if (Selet_dtm("1012") >= STEP_P4)//温度
+ {
+ Updata_dtd("3039",false);
+
+ if (Selet_dtd("2003"))//投料确认
+ {
+ if (STEP_TIME <= 0)//搅拌
+ {
+ TANK1 = Resources.Ready + Resources.Finish;
+ Updata_dtd("3040",false);
+ STEP_finish = true;
+ }
+ else
+ {
+ STEP_TIME--;
+ Updata_dtd("3040",true);
+ }
+ Alert_yellow = false;
+ Alert_bell = false;
+ }
+ else
+ {
+ Alert_yellow = true;
+ STEP_TIME = Convert.ToInt16(STEP_P5);
+ Alert_bell = true;
+ }
+ }
+ else
+ {
+ Updata_dtd("3039",true);
+ Updata_dtd("3040", true);
+ }
+ }
+ else
+ {
+ if (STEP_P2 == 0) Updata_dtd("3038", true);
+ else if(STEP_P2 == 1) Updata_dtd("3036", true);
+ else if (STEP_P2 == 2) Updata_dtd("3037", true);
+ }
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank +" 1 :" + Resources.Ready;
+ } //药缸1
+ else if (STEP_P1 == 2)
+ {
+ if (Selet_dtm("1018") >= STEP_P3)//水位
+ {
+ TANK2 = Resources.Ready;
+ Updata_dtd("3046", false);
+ Updata_dtd("3047", false);
+ Updata_dtd("3048", false);
+ if (Selet_dtm("1013") >= STEP_P4)//温度
+ {
+ Updata_dtd("3049", false);
+
+ if (Selet_dtd("2003"))//投料确认
+ {
+ if (STEP_TIME <= 0)//搅拌
+ {
+ TANK2 = Resources.Ready + Resources.Finish;
+ Updata_dtd("3050", false);
+ STEP_finish = true;
+ }
+ else
+ {
+ STEP_TIME--;
+ Updata_dtd("3050", true);
+ }
+ Alert_yellow = false;
+ Alert_bell = false;
+ }
+ else
+ {
+ Alert_yellow = true;
+ STEP_TIME = Convert.ToInt16(STEP_P5);
+ Alert_bell = true;
+ }
+ }
+ else
+ {
+ Updata_dtd("3049", true);
+ Updata_dtd("3050", true);
+ }
+ }
+ else
+ {
+ if (STEP_P2 == 0) Updata_dtd("3048", true);
+ else if (STEP_P2 == 1) Updata_dtd("3046", true);
+ else if (STEP_P2 == 2) Updata_dtd("3047", true);
+ }
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 2 :" + Resources.Ready;
+ }//药缸2
+ else if (STEP_P1 == 3)
+ {
+ if (Selet_dtm("1019") >= STEP_P3)//水位
+ {
+ TANK3 = Resources.Ready;
+ Updata_dtd("3056", false);
+ Updata_dtd("3057", false);
+ Updata_dtd("3058", false);
+
+ if (Selet_dtm("1014") >= STEP_P4)//温度
+ {
+ Updata_dtd("3059", false);
+
+ if (Selet_dtd("2003"))//投料确认
+ {
+ if (STEP_TIME <= 0)//搅拌
+ {
+ TANK3 = Resources.Ready + Resources.Finish;
+ Updata_dtd("3060", false);
+ STEP_finish = true;
+ }
+ else
+ {
+ STEP_TIME--;
+ Updata_dtd("3060", true);
+ }
+ Alert_yellow = false;
+ Alert_bell = false;
+ }
+ else
+ {
+ Alert_yellow = true;
+ STEP_TIME = Convert.ToInt16(STEP_P5);
+ Alert_bell = true;
+ }
+ }
+ else
+ {
+ Updata_dtd("3059", true);
+ Updata_dtd("3060", true);
+ }
+ }
+ else
+ {
+ if (STEP_P2 == 0) Updata_dtd("3058", true);
+ else if (STEP_P2 == 1) Updata_dtd("3056", true);
+ else if (STEP_P2 == 2) Updata_dtd("3057", true);
+ }
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 3 :" + Resources.Ready;
+ }//药缸3
break;//药缸备药
case "065":
-
+ if ((STEP_P1 == 1) || (STEP_P1 == 0))
+ {
+
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 1 :" + Resources.AddTheMedicine;
+ } //药缸1
+ else if (STEP_P1 == 2)
+ {
+
+
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 2 :" + Resources.AddTheMedicine;
+ }//药缸2
+ else if (STEP_P1 == 3)
+ {
+
+
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 3 :" + Resources.AddTheMedicine;
+ }//药缸3
break;//药缸加药
case "066":
-
+ if (STEP_P1 == 1)
+ {
+ TANK1_REDYE = SYS_REDYE;
+ if(string.IsNullOrEmpty(TANK1_DYELOT)) TANK1_DYELOT = WorkNumder.ToString();
+ TANK1_STEP =Convert.ToInt16(STEP_P3);
+ FeedingRecords(work_Numder,TANK1_DYELOT,Convert.ToInt16(STEP_P1),TANK1_STEP,Convert.ToInt16(STEP_P2));//调用呼叫
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 1 :" + Resources.CallDistribution;
+ STEP_finish = true;
+ } //药缸1
+ else if (STEP_P1 == 2)
+ {
+ TANK2_REDYE = SYS_REDYE;
+ if (string.IsNullOrEmpty(TANK2_DYELOT)) TANK2_DYELOT = WorkNumder.ToString();
+ TANK2_STEP = Convert.ToInt16(STEP_P3);
+ FeedingRecords(work_Numder, TANK2_DYELOT, Convert.ToInt16(STEP_P1), TANK2_STEP, Convert.ToInt16(STEP_P2));//调用呼叫
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 2 :" + Resources.CallDistribution;
+ STEP_finish = true;
+ }//药缸2
+ else if (STEP_P1 == 3)
+ {
+ TANK3_REDYE = SYS_REDYE;
+ if (string.IsNullOrEmpty(TANK3_DYELOT)) TANK3_DYELOT = WorkNumder.ToString();
+ TANK3_STEP = Convert.ToInt16(STEP_P3);
+ FeedingRecords(work_Numder, TANK3_DYELOT, Convert.ToInt16(STEP_P1), TANK3_STEP, Convert.ToInt16(STEP_P2));//调用呼叫
+ if (string.IsNullOrEmpty(Name_err.ToString())) Status_Str = Resources.Tank + " 3 :" + Resources.CallDistribution;
+ STEP_finish = true;
+ }//药缸3
+ //STEP_finish = true;
break;//呼叫输送
case "067":
- break;//呼叫输送
+ STEP_finish = true;
+ break;//呼叫输送准备
case "090":
break;//快速加酸
@@ -1013,6 +1265,38 @@ namespace DyeingComputer.ViewModel
}
}
+ void FeedingRecords(string WorkOrder,string Dyelot,int TANK,int STEP,int Type) //呼叫输送
+ {
+ DataTable data_t = new DataTable();
+ data_t.Columns.Add("Dyelot", typeof(string)); //添加列
+ data_t.Columns.Add("Machine", typeof(string));
+ data_t.Columns.Add("WorkOrder", typeof(string));
+ data_t.Columns.Add("TIME", typeof(string));
+ data_t.Columns.Add("Tank", typeof(int));
+ data_t.Columns.Add("STEP", typeof(int));
+ data_t.Columns.Add("Type", typeof(int));
+ data_t.Columns.Add("State", typeof(int));
+ data_t.Columns.Add("Redye", typeof(int));
+ DataRow dr = data_t.NewRow();
+ dr.BeginEdit(); //添加订单号
+ dr["Dyelot"] = Dyelot;
+ dr["Machine"] = S01;
+ dr["WorkOrder"] = WorkOrder;
+ dr["TIME"] = sys_Time;
+ dr["Tank"] = TANK;
+ dr["STEP"] = STEP;
+ dr["Type"] = Type;
+ dr["State"] = 201;
+ dr["Redye"] = SYS_REDYE;
+ dr.EndEdit();
+ data_t.Rows.InsertAt(dr, 0); //行转换
+
+ SQLiteHelpers = new SQLiteHelper(DBAddress); //数据库连接路径
+ SQLiteHelpers.Open(); //打开数据库
+ SQLiteHelpers.InsertData("FeedingRecords", SQLiteHelpers.DataTableToDictionary(data_t));//行插入
+ SQLiteHelpers.Close(); //关闭连接
+ }
+
public static SerialPort port = new SerialPort();//创建串口
static ModbusFactory factory = new ModbusFactory();
// Create Modbus Master
@@ -1036,7 +1320,7 @@ namespace DyeingComputer.ViewModel
LogGing.LogGingDATA(e.Message);
Name_err = "800_SerialPort_Not";
}
- }
+ }//ck
private bool LINK_OK = false;
private int LINK_RUN = 0;
private int LINK_ERR = 0;
@@ -1145,21 +1429,21 @@ namespace DyeingComputer.ViewModel
if (SM01 == 1)
{
Sys_log = Sys_log + "\n" + Resources.Medicine + Resources.Tank + "1 => [" + Resources.WaterLevel + ":" + string.Format("{0:D4}", Convert.ToInt16(Selet_dtm("1017"))) + "L][" + Resources.Temperature + ":" + string.Format(" {0:###.#}", Convert.ToInt16(Selet_dtm("1012"))) + "°C]";
- Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + " => ";
- Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : ";
- }
+ Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + TANK1_DYELOT +"_"+ TANK1_REDYE + " => "+ TANK1_STEP;
+ Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : "+TANK1;
+ }//附缸1
if (SM02 == 1)
{
Sys_log = Sys_log + "\n" + Resources.Medicine + Resources.Tank + "2 => [" + Resources.WaterLevel + ":" + string.Format("{0:D4}", Convert.ToInt16(Selet_dtm("1018"))) + "L][" + Resources.Temperature + ":" + string.Format(" {0:###.#}", Convert.ToInt16(Selet_dtm("1013"))) + "°C]";
- Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + " => ";
- Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : ";
- }
+ Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + TANK2_DYELOT + "_" + TANK1_REDYE + " => " + TANK2_STEP;
+ Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : "+TANK2;
+ }//附缸2
if (SM03 == 1)
{
Sys_log = Sys_log + "\n" + Resources.Medicine + Resources.Tank + "3 => [" + Resources.WaterLevel + ":" + string.Format("{0:D4}", Convert.ToInt16(Selet_dtm("1019"))) + "L][" + Resources.Temperature + ":" + string.Format(" {0:###.#}", Convert.ToInt16(Selet_dtm("1014"))) + "°C]";
- Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + " => ";
- Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : ";
- }
+ Sys_log = Sys_log + "\n" + Resources.Dyelot + " : " + TANK3_DYELOT + "_" + TANK1_REDYE + " => " + TANK3_STEP;
+ Sys_log = Sys_log + "\n" + Resources.WorkingStatus + " : "+TANK3;
+ }//附缸3
}
public static DataTable dt_d = new DataTable("DIO");
public static DataTable dt_a = new DataTable("AIO");
@@ -1343,7 +1627,6 @@ namespace DyeingComputer.ViewModel
LogGing.LogGingDATA("UDTA:" + ex.ToString());
}
}
-
public static void Upplc_dtd(string key, bool Value)//更新PLCD
{
try
diff --git a/Windows/ViewStep.xaml.cs b/Windows/ViewStep.xaml.cs
index 9c44c98..86cadb8 100644
--- a/Windows/ViewStep.xaml.cs
+++ b/Windows/ViewStep.xaml.cs
@@ -411,15 +411,14 @@ namespace DyeingComputer.Windows
P1N.Text = Properties.Resources.Medicine + Properties.Resources.Tank;
P2N.Text = Properties.Resources.Type;
P3N.Text = Properties.Resources.Step;
- P4N.Text = Properties.Resources.Advance+Properties.Resources.Time;
P1.Visibility = Visibility.Visible;
P1N.Visibility = Visibility.Visible;
P2.Visibility = Visibility.Visible;
P2N.Visibility = Visibility.Visible;
P3.Visibility = Visibility.Visible;
P3N.Visibility = Visibility.Visible;
- P4.Visibility = Visibility.Visible;
- P4N.Visibility = Visibility.Visible;
+ P4.Visibility = Visibility.Collapsed;
+ P4N.Visibility = Visibility.Collapsed;
P5.Visibility = Visibility.Collapsed;
P5N.Visibility = Visibility.Collapsed;
break;