簡單介紹一下項目背景:數據庫
你們喜好的葡萄酒須要通過原料選擇→分選→去梗→破碎→消毒→前發酵→壓榨→調整酒度→後發酵→貯藏→沉清過濾→裝瓶、殺菌這幾個過程,多線程
保溫發酵控制系統是其中重要一環,葡萄酒通過前期工藝後,在發酵罐常期進行發酵,溫度必須保證在必定範圍,溫度高時須要製冷。溫度高了須要app
進行攪拌,不至於結冰。往復的過程。this
在項目中運用到數據庫、多線程、現場採集、液位顯示等。spa
動態顯示每一個發酵罐或者保溫罐相關信息與參數,能夠設定製定控制仍是手動控制。線程
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Windows.Forms; using ZedGraph; namespace work { public partial class FormDisplay : Form { // Starting time in milliseconds int tickStart = 0; string obj_gh; string device; public DataSet ds; private System.Windows.Forms.DataGridTableStyle ts; public FormDisplay(string gh) { obj_gh = gh; InitializeComponent(); } private void FillData(string gh) { DataSet dsmatno; string selectmatno = " select mname from matno "; selectmatno = selectmatno + " order by matnoid desc"; dsmatno = Narnu.GetDataSetByOleDbString(selectmatno); cb_pm.DataSource = dsmatno.Tables[0]; cb_pm.DisplayMember = "mname"; datagrid.TableStyles.Clear(); ts = new DataGridTableStyle(); ts.RowHeadersVisible = false; DataSet ds; string selectgh = " select * from wd "; selectgh =selectgh + " where gh = '" + gh.ToString()+ "'" + " order by tkdat1 desc"; ds = Narnu.GetDataSetByOleDbString(selectgh); ts.MappingName = ds.Tables[0].TableName; //ts.AlternatingBackColor = Color.LightSkyBlue; ts.AllowSorting = false; //id, palno, addre, addre_desc, trans, trans_ssj, trans_ddj, deviceno, //xd, statu, deviceno_desc, port, port_desc, ssj, ddj, pri, error, fflag, tkdat setcolumn("gh", "罐號", 120); setcolumn("op", "操做", 120); setcolumn("sdwd", "設定溫度", 120); setcolumn("sjwd1", "高位溫度", 120); setcolumn("sjwd2", "低位溫度", 120); setcolumn("tkdat1", "時間", 120); setcolumn("deviceno", "設備號", 40); setcolumn("trans", "電報", 150); setcolumn("statu", "狀態", 50); setcolumn("error", "故障信息", 150); setcolumn("tkdat", "產生時間", 120); setcolumn("xd", "巷道", 50); setcolumn("port", "口地址", 50); setcolumn("if_do", "狀態", 40); setcolumn("alock", "鎖定狀態", 40); setcolumn("sectn", "庫區", 40); datagrid.TableStyles.Add(ts); this.datagrid.DataSource = ds.Tables[0]; this.dataGridView1.DataSource = ds.Tables[0]; } private void FillDataTk(string gh,DateTime tk) { datagrid.TableStyles.Clear(); ts = new DataGridTableStyle(); ts.RowHeadersVisible = false; DataSet ds; string selectgh = " select * from wd "; selectgh = selectgh + " where gh = '" + gh.ToString() + "'" + " and tkdat1>=Cdate('" + tk + "')" + " order by tkdat1 desc"; ds = Narnu.GetDataSetByOleDbString(selectgh); ts.MappingName = ds.Tables[0].TableName; //ts.AlternatingBackColor = Color.LightSkyBlue; ts.AllowSorting = false; //id, palno, addre, addre_desc, trans, trans_ssj, trans_ddj, deviceno, //xd, statu, deviceno_desc, port, port_desc, ssj, ddj, pri, error, fflag, tkdat setcolumn("sdwd", "設定溫度", 120); setcolumn("sjwd1", "高位溫度", 120); setcolumn("sjwd2", "低位溫度", 120); setcolumn("gh", "罐號", 120); setcolumn("op", "操做", 120); setcolumn("tkdat1", "時間", 120); setcolumn("deviceno", "設備號", 40); setcolumn("trans", "電報", 150); setcolumn("statu", "狀態", 50); setcolumn("error", "故障信息", 150); setcolumn("tkdat", "產生時間", 120); setcolumn("xd", "巷道", 50); setcolumn("port", "口地址", 50); setcolumn("if_do", "狀態", 40); setcolumn("alock", "鎖定狀態", 40); setcolumn("sectn", "庫區", 40); datagrid.TableStyles.Add(ts); this.datagrid.DataSource = ds.Tables[0]; this.dataGridView1.DataSource = ds.Tables[0]; } private void setcolumn(string name, string text, int width) { DataGridTextBoxColumn C = new DataGridTextBoxColumn(); // DataGridColumnStyle CStyle = new DataGridColumnStyle(); //youFirstFieldName是你的Table裏的某個字段名 C.MappingName = name; //youHeaderName是你但願將上面這個字段顯示在DataGrid裏時的標題 C.HeaderText = text; C.Width = width; C.Alignment = HorizontalAlignment.Center; //響應鼠標單擊與雙擊事件 // C.TextBox.MouseDown += new MouseEventHandler(TextBoxMouseDownHandler); ts.GridColumnStyles.Add(C); C.Dispose(); } private void Form1_Load( object sender, EventArgs e ) { // TODO: 這行代碼將數據加載到表「bookShopDataSet.wd」中。您能夠根據須要移動或移除它。 //this.wdTableAdapter.Fill(this.bookShopDataSet.wd); //foreach (Form froms in this)//檢查窗體是否存在 //{ // if (froms is work.FormDisplay) // { // froms.Focus();//得到焦點 // return;//退出過程 // } //} // MessageBox.Show(obj_gh); dateTimePicker1.Value = DateTime.Now.AddDays(-1); string gh = ""; lb_gh.Text = obj_gh.Substring(0, 4).ToUpper() ; gh = obj_gh.Substring(0, 4).ToUpper(); device = obj_gh.Substring(5, 2); // MessageBox.Show(device); GraphPane myPane = zedGraphControl1.GraphPane; myPane.Title.Text = "溫度實時曲線\n"; myPane.XAxis.Title.Text = "時間, 秒"; myPane.YAxis.Title.Text = "溫度"; old_wd.Text = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; sd_wd.Text = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; // Save 1200 points. At 50 ms sample rate, this is one minute // The RollingPointPairList is an efficient storage class that always // keeps a rolling set of point data without needing to shift any data values //設置1200個點,假設每50毫秒更新一次,恰好檢測1分鐘 //一旦構造後將不能更改這個值 RollingPointPairList list = new RollingPointPairList( 1200 ); // Initially, a curve is added with no data points (list is empty) // Color is blue, and there will be no symbols //開始,增長的線是沒有數據點的(也就是list爲空) //增長一條名稱:Voltage,顏色Color.Bule,無符號,無數據的空線條 LineItem curve = myPane.AddCurve( "溫度", list, Color.Blue, SymbolType.None ); // Sample at 50ms intervals //設置timer控件的間隔爲50毫秒 timer1.Interval = 50; timer1.Enabled = true; timer1.Start(); // Just manually control the X axis range so it scrolls continuously // instead of discrete step-sized jumps myPane.XAxis.Scale.Min = 0; //X軸最小值0 myPane.XAxis.Scale.Max = 30; //X軸最大30 myPane.XAxis.Scale.MinorStep = 1; //X軸小步長1,也就是小間隔 myPane.XAxis.Scale.MajorStep = 5; //X軸大步長爲5,也就是顯示文字的大間隔 // Scale the axes //改變軸的刻度 zedGraphControl1.AxisChange(); // Save the beginning time for reference //保存開始時間 tickStart = Environment.TickCount; // DataSet ds; string selectgh = " select * from gh where gh = '" + gh + "'" + " and finish='" + "1" + "' order by tkdat1 desc"; ds = Narnu.GetDataSetByOleDbString(selectgh); if (ds.Tables["gh"].Rows.Count == 0) { cb_pm.Text = ""; tb_batch.Text = ""; bt_st.Enabled = true; bt_com.Enabled = false; //cb_pm } else { cb_pm.Text = ds.Tables["gh"].Rows[0][6].ToString(); tb_batch.Text = ds.Tables["gh"].Rows[0][5].ToString(); bt_st.Enabled = false; bt_com.Enabled = true; } FillData(gh.ToString()); //string gh = ""; lb_gh.Text = obj_gh.Substring(0, 4).ToUpper(); gh = obj_gh.Substring(0, 4).ToUpper(); device = obj_gh.Substring(5, 2); DateTime tk; //DataSet ds; tk = Convert.ToDateTime(dateTimePicker1.Value); // selectgh = " select * from gh where gh = '" + gh + "'" + " and tkdat1>=Cdate('" + tk + "')" + " and finish='" + "1" + "' order by tkdat1 desc"; //ds = Narnu.GetDataSetByOleDbString(selectgh); //if (ds.Tables["gh"].Rows.Count == 0) //{ // cb_pm.Text = ""; // tb_batch.Text = ""; // bt_st.Enabled = true; // bt_com.Enabled = false; // //cb_pm //} //else //{ // cb_pm.Text = ds.Tables["gh"].Rows[0][6].ToString(); // tb_batch.Text = ds.Tables["gh"].Rows[0][5].ToString(); // bt_st.Enabled = false; // bt_com.Enabled = true; //} FillDataTk(gh.ToString(), tk); } private void timer1_Tick( object sender, EventArgs e ) { if (MainForm.pMainWin.zhileng[Convert.ToInt32(device)-1] == 1) { if (sg22_17_01.State != LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Blink) { sg22_17_01.State = LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Blink; } } if (MainForm.pMainWin.zhileng[Convert.ToInt32(device)-1] == 0) { sg22_17_01.State = LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Off; //LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Off; ; } if (MainForm.pMainWin.jiaoban[Convert.ToInt32(device)-1] == 1) { if (sf09_12_dj.State != LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Blink) { sf09_12_dj.State = LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Blink; } } if (MainForm.pMainWin.jiaoban[Convert.ToInt32(device)-1] == 0) { sf09_12_dj.State = LBSoft.IndustrialCtrls.Leds.LBLed.LedState.Off; } // Make sure that the curvelist has at least one curve //確保CurveList不爲空 double var=3; var = Convert.ToDouble(MainForm.pMainWin.sjwd1[Convert.ToInt32(device)-1]); if ( zedGraphControl1.GraphPane.CurveList.Count <= 0 ) return; // Get the first CurveItem in the graph //取Graph第一個曲線,也就是第一步:在GraphPane.CurveList集合中查找CurveItem LineItem curve = zedGraphControl1.GraphPane.CurveList[0] as LineItem; if ( curve == null ) return; // Get the PointPairList //第二步:在CurveItem中訪問PointPairList(或者其它的IPointList),根據本身的須要增長新數據或修改已存在的數據 IPointListEdit list = curve.Points as IPointListEdit; // If this is null, it means the reference at curve.Points does not // support IPointListEdit, so we won't be able to modify it if ( list == null ) return; // Time is measured in seconds double time = ( Environment.TickCount - tickStart ) / 10000.0; // 3 seconds per cycle //list.Add( time, Math.Sin( 2.0 * Math.PI * time / 3.0 ) ); list.Add(time,var); //var = MainForm.pMainWin. // Keep the X scale at a rolling 30 second interval, with one // major step between the max X value and the end of the axis Scale xScale = zedGraphControl1.GraphPane.XAxis.Scale; if ( time > xScale.Max - xScale.MajorStep ) { xScale.Max = time + xScale.MajorStep; xScale.Min = xScale.Max - 30.0; } // Make sure the Y axis is rescaled to accommodate actual data //第三步:調用ZedGraphControl.AxisChange()方法更新X和Y軸的範圍 zedGraphControl1.AxisChange(); // Force a redraw //第四步:調用Form.Invalidate()方法更新圖表 zedGraphControl1.Invalidate(); } private void Form1_Resize( object sender, EventArgs e ) { //SetSize(); } // Set the size and location of the ZedGraphControl private void SetSize() { } private void button1_Click(object sender, EventArgs e) { string device_write=""; int deviceno; deviceno = Convert.ToInt32(device); if (deviceno == 1) { device_write = "64"; } if (deviceno == 2) { device_write = "65"; } if (deviceno == 3) { device_write = "66"; } if (deviceno == 4) { device_write = "67"; } if (deviceno == 5) { device_write = "44"; } if (deviceno == 6) { device_write = "45"; } if (deviceno == 7) { device_write = "46"; } if (deviceno == 8) { device_write = "47"; } if (deviceno == 9) { device_write = "52"; } if (deviceno == 10) { device_write = "53"; } if (deviceno == 11) { device_write = "54"; } if (deviceno == 12) { device_write = "55"; } if (deviceno == 13) { device_write = "60"; } if (deviceno == 14) { device_write = "61"; } if (deviceno == 15) { device_write = "62"; } if (deviceno == 16) { device_write = "63"; } if (deviceno == 17) { device_write = "68"; } if (deviceno == 18) { device_write = "69"; } if (deviceno == 19) { device_write = "70"; } if (deviceno == 20) { device_write = "71"; } DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否關閉電磁閥" + "\r"); if (result == DialogResult.No) { return; } MainForm.pMainWin.objPlc1.Writeplc(device_write, "0"); string tkdat1 = ""; string tkdat2 = ""; string userid = "admin"; string pm = ""; string batch = ""; string gh = ""; string SetValue; string insertgh; string sdwd_t = ""; string sjwd1_t = ""; string sjwd2_t = ""; string yali_t = ""; string op_t = ""; op_t ="關閉電磁閥"; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; tkdat1 = DateTime.Now.ToString(); tkdat2 = DateTime.Now.ToString(); gh = obj_gh.Substring(0, 4).ToUpper(); yali_t = MainForm.pMainWin.yl[Convert.ToInt32(device) - 1]; ; sdwd_t = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; ; sjwd1_t = MainForm.pMainWin.sjwd1[Convert.ToInt32(device) - 1]; ; sjwd2_t = MainForm.pMainWin.sjwd2[Convert.ToInt32(device) - 1]; ; SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "','" + yali_t + "','" + sdwd_t + "','" + sjwd1_t + "','"+ op_t + "','" + sjwd2_t + "')"; insertgh = "insert into wd (pm,gh,batch,tkdat1,tkdat2,userid,finish,yl,sdwd,sjwd1,op,sjwd2) values " + SetValue; try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MainForm.pMainWin.ls_IniFile.WriteLog("write1", ex.Message.ToString()); return; } } private void button5_Click(object sender, EventArgs e) { string device_write = ""; int deviceno; deviceno = Convert.ToInt32(device); if (deviceno == 1) { device_write = "64"; } if (deviceno == 2) { device_write = "65"; } if (deviceno == 3) { device_write = "66"; } if (deviceno == 4) { device_write = "67"; } if (deviceno == 5) { device_write = "44"; } if (deviceno == 6) { device_write = "45"; } if (deviceno == 7) { device_write = "46"; } if (deviceno == 8) { device_write = "47"; } if (deviceno == 9) { device_write = "52"; } if (deviceno == 10) { device_write = "53"; } if (deviceno == 11) { device_write = "54"; } if (deviceno == 12) { device_write = "55"; } if (deviceno == 13) { device_write = "60"; } if (deviceno == 14) { device_write = "61"; } if (deviceno == 15) { device_write = "62"; } if (deviceno == 16) { device_write = "63"; } if (deviceno == 17) { device_write = "68"; } if (deviceno == 18) { device_write = "69"; } if (deviceno == 19) { device_write = "70"; } if (deviceno == 20) { device_write = "71"; } //device //zhileng[0] = Convert.ToInt32(objPlc1.ReadPlc("64")); //MessageBox.Show(zhileng[0].ToString()); //zhileng[1] = Convert.ToInt32(objPlc1.ReadPlc("65")); //zhileng[2] = Convert.ToInt32(objPlc1.ReadPlc("66")); //zhileng[3] = Convert.ToInt32(objPlc1.ReadPlc("67")); //zhileng[4] = Convert.ToInt32(objPlc1.ReadPlc("44")); //zhileng[5] = Convert.ToInt32(objPlc1.ReadPlc("45")); //zhileng[6] = Convert.ToInt32(objPlc1.ReadPlc("46")); //zhileng[7] = Convert.ToInt32(objPlc1.ReadPlc("47")); //zhileng[8] = Convert.ToInt32(objPlc1.ReadPlc("52")); //zhileng[9] = Convert.ToInt32(objPlc1.ReadPlc("53")); //zhileng[10] = Convert.ToInt32(objPlc1.ReadPlc("54")); //zhileng[11] = Convert.ToInt32(objPlc1.ReadPlc("55")); //zhileng[12] = Convert.ToInt32(objPlc1.ReadPlc("60")); //zhileng[13] = Convert.ToInt32(objPlc1.ReadPlc("61")); //zhileng[14] = Convert.ToInt32(objPlc1.ReadPlc("62")); //zhileng[15] = Convert.ToInt32(objPlc1.ReadPlc("63")); //zhileng[16] = Convert.ToInt32(objPlc1.ReadPlc("68")); //zhileng[17] = Convert.ToInt32(objPlc1.ReadPlc("69")); //zhileng[18] = Convert.ToInt32(objPlc1.ReadPlc("70")); //zhileng[19] = Convert.ToInt32(objPlc1.ReadPlc("71")); DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否開啓電磁閥" + "\r"); if (result == DialogResult.No) { return; } MainForm.pMainWin.objPlc1.Writeplc(device_write, "1"); string tkdat1 = ""; string tkdat2 = ""; string userid = "admin"; string pm = ""; string batch = ""; string gh = ""; string SetValue; string insertgh; string sdwd_t = ""; string sjwd1_t = ""; string sjwd2_t = ""; string yali_t = ""; string op_t = ""; op_t = "開啓電磁閥"; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; tkdat1 = DateTime.Now.ToString(); tkdat2 = DateTime.Now.ToString(); gh = obj_gh.Substring(0, 4).ToUpper(); yali_t = MainForm.pMainWin.yl[Convert.ToInt32(device) - 1]; ; sdwd_t = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; ; sjwd1_t = MainForm.pMainWin.sjwd1[Convert.ToInt32(device) - 1]; ; sjwd2_t = MainForm.pMainWin.sjwd2[Convert.ToInt32(device) - 1]; ; SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "','" + yali_t + "','" + sdwd_t + "','" + sjwd1_t + "','" + op_t + "','" + sjwd2_t + "')"; insertgh = "insert into wd (pm,gh,batch,tkdat1,tkdat2,userid,finish,yl,sdwd,sjwd1,op,sjwd2) values " + SetValue; try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MainForm.pMainWin.ls_IniFile.WriteLog("write1", ex.Message.ToString()); return; } } private void button4_Click(object sender, EventArgs e) { string device_write=""; int deviceno; deviceno = Convert.ToInt32(device); if (deviceno == 1) { device_write="30"; } if (deviceno == 2) { device_write="31"; } if (deviceno == 3) { device_write="32"; } if (deviceno == 4) { device_write="33"; } if (deviceno == 5) { device_write="34"; } if (deviceno == 6) { device_write="35"; } if (deviceno == 7) { device_write = "36"; } if (deviceno == 8) { device_write="37"; } if (deviceno ==9) { device_write="40"; } if (deviceno == 10) { device_write="41"; } if (deviceno == 11) { device_write = "42"; } if (deviceno == 12) { device_write = "43"; } if (deviceno == 13) { device_write = "48"; } if (deviceno == 14) { device_write = "49"; } if (deviceno == 15) { device_write = "50"; } if (deviceno == 16) { device_write = "51"; } if (deviceno == 17) { device_write = "56"; } if (deviceno == 18) { device_write = "57"; } if (deviceno == 19) { device_write = "58"; } if (deviceno == 20) { device_write = "59"; } //device //jiaoban[0] = Convert.ToInt32(objPlc1.ReadPlc("30")); //jiaoban[1] = Convert.ToInt32(objPlc1.ReadPlc("31")); //jiaoban[2] = Convert.ToInt32(objPlc1.ReadPlc("32")); //jiaoban[3] = Convert.ToInt32(objPlc1.ReadPlc("33")); //jiaoban[4] = Convert.ToInt32(objPlc1.ReadPlc("34")); //jiaoban[5] = Convert.ToInt32(objPlc1.ReadPlc("35")); //jiaoban[6] = Convert.ToInt32(objPlc1.ReadPlc("36")); //jiaoban[7] = Convert.ToInt32(objPlc1.ReadPlc("37")); //jiaoban[8] = Convert.ToInt32(objPlc1.ReadPlc("40")); //jiaoban[9] = Convert.ToInt32(objPlc1.ReadPlc("41")); //jiaoban[10] = Convert.ToInt32(objPlc1.ReadPlc("42")); //jiaoban[11] = Convert.ToInt32(objPlc1.ReadPlc("43")); //jiaoban[12] = Convert.ToInt32(objPlc1.ReadPlc("48")); //jiaoban[14] = Convert.ToInt32(objPlc1.ReadPlc("50")); //jiaoban[15] = Convert.ToInt32(objPlc1.ReadPlc("51")); //jiaoban[16] = Convert.ToInt32(objPlc1.ReadPlc("56")); //jiaoban[17] = Convert.ToInt32(objPlc1.ReadPlc("57")); //jiaoban[18] = Convert.ToInt32(objPlc1.ReadPlc("58")); //jiaoban[19] = Convert.ToInt32(objPlc1.ReadPlc("59")); DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否關閉攪拌" + "\r"); if (result == DialogResult.No) { return; } MainForm.pMainWin.objPlc1.Writeplc(device_write, "0"); string tkdat1 = ""; string tkdat2 = ""; string userid = "admin"; string pm = ""; string batch = ""; string gh = ""; string SetValue; string insertgh; string sdwd_t = ""; string sjwd1_t = ""; string sjwd2_t = ""; string yali_t = ""; string op_t = ""; op_t = "關閉攪拌"; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; tkdat1 = DateTime.Now.ToString(); tkdat2 = DateTime.Now.ToString(); gh = obj_gh.Substring(0, 4).ToUpper(); yali_t = MainForm.pMainWin.yl[Convert.ToInt32(device) - 1]; ; sdwd_t = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; ; sjwd1_t = MainForm.pMainWin.sjwd1[Convert.ToInt32(device) - 1]; ; sjwd2_t = MainForm.pMainWin.sjwd2[Convert.ToInt32(device) - 1]; ; SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "','" + yali_t + "','" + sdwd_t + "','" + sjwd1_t + "','" + op_t + "','" + sjwd2_t + "')"; insertgh = "insert into wd (pm,gh,batch,tkdat1,tkdat2,userid,finish,yl,sdwd,sjwd1,op,sjwd2) values " + SetValue; try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MainForm.pMainWin.ls_IniFile.WriteLog("write1", ex.Message.ToString()); return; } } private void button2_Click(object sender, EventArgs e) { string device_write=""; int deviceno; deviceno = Convert.ToInt32(device); if (deviceno == 1) { device_write = "30"; } if (deviceno == 2) { device_write = "31"; } if (deviceno == 3) { device_write = "32"; } if (deviceno == 4) { device_write = "33"; } if (deviceno == 5) { device_write = "34"; } if (deviceno == 6) { device_write = "35"; } if (deviceno == 7) { device_write = "36"; } if (deviceno == 8) { device_write = "37"; } if (deviceno == 9) { device_write = "40"; } if (deviceno == 10) { device_write = "41"; } if (deviceno == 11) { device_write = "42"; } if (deviceno == 12) { device_write = "43"; } if (deviceno == 13) { device_write = "48"; } if (deviceno == 14) { device_write = "49"; } if (deviceno == 15) { device_write = "50"; } if (deviceno == 16) { device_write = "51"; } if (deviceno == 17) { device_write = "56"; } if (deviceno == 18) { device_write = "57"; } if (deviceno == 19) { device_write = "58"; } if (deviceno == 20) { device_write = "59"; } //device //jiaoban[0] = Convert.ToInt32(objPlc1.ReadPlc("30")); //jiaoban[1] = Convert.ToInt32(objPlc1.ReadPlc("31")); //jiaoban[2] = Convert.ToInt32(objPlc1.ReadPlc("32")); //jiaoban[3] = Convert.ToInt32(objPlc1.ReadPlc("33")); //jiaoban[4] = Convert.ToInt32(objPlc1.ReadPlc("34")); //jiaoban[5] = Convert.ToInt32(objPlc1.ReadPlc("35")); //jiaoban[6] = Convert.ToInt32(objPlc1.ReadPlc("36")); //jiaoban[7] = Convert.ToInt32(objPlc1.ReadPlc("37")); //jiaoban[8] = Convert.ToInt32(objPlc1.ReadPlc("40")); //jiaoban[9] = Convert.ToInt32(objPlc1.ReadPlc("41")); //jiaoban[10] = Convert.ToInt32(objPlc1.ReadPlc("42")); //jiaoban[11] = Convert.ToInt32(objPlc1.ReadPlc("43")); //jiaoban[12] = Convert.ToInt32(objPlc1.ReadPlc("48")); //jiaoban[14] = Convert.ToInt32(objPlc1.ReadPlc("50")); //jiaoban[15] = Convert.ToInt32(objPlc1.ReadPlc("51")); //jiaoban[16] = Convert.ToInt32(objPlc1.ReadPlc("56")); //jiaoban[17] = Convert.ToInt32(objPlc1.ReadPlc("57")); //jiaoban[18] = Convert.ToInt32(objPlc1.ReadPlc("58")); //jiaoban[19] = Convert.ToInt32(objPlc1.ReadPlc("59")); DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否開啓攪拌" + "\r"); if (result == DialogResult.No) { return; } MainForm.pMainWin.objPlc1.Writeplc(device_write, "1"); string tkdat1 = ""; string tkdat2 = ""; string userid = "admin"; string pm = ""; string batch = ""; string gh = ""; string SetValue; string insertgh; string sdwd_t = ""; string sjwd1_t = ""; string sjwd2_t = ""; string yali_t = ""; string op_t = ""; op_t = "開啓攪拌"; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; tkdat1 = DateTime.Now.ToString(); tkdat2 = DateTime.Now.ToString(); gh = obj_gh.Substring(0, 4).ToUpper(); yali_t = MainForm.pMainWin.yl[Convert.ToInt32(device) - 1]; ; sdwd_t = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; ; sjwd1_t = MainForm.pMainWin.sjwd1[Convert.ToInt32(device) - 1]; ; sjwd2_t = MainForm.pMainWin.sjwd2[Convert.ToInt32(device) - 1]; ; SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "','" + yali_t + "','" + sdwd_t + "','" + sjwd1_t + "','" + op_t + "','" + sjwd2_t + "')"; insertgh = "insert into wd (pm,gh,batch,tkdat1,tkdat2,userid,finish,yl,sdwd,sjwd1,op,sjwd2) values " + SetValue; try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MainForm.pMainWin.ls_IniFile.WriteLog("write1", ex.Message.ToString()); return; } } private void button3_Click(object sender, EventArgs e) { string op_t = ""; DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否執行操做" + "\r"); if (result == DialogResult.No) { return; } if (rb_auto.Checked) { MainForm.pMainWin.op[Convert.ToInt32(device) - 1] = 1; MainForm.pMainWin.start[Convert.ToInt32(device) - 1] = 1; op_t = "開啓自動"; } if (rb_man.Checked) { MainForm.pMainWin.op[Convert.ToInt32(device) - 1] = 0; MainForm.pMainWin.start[Convert.ToInt32(device) - 1] = 0; op_t = "開啓手動"; } string tkdat1 = ""; string tkdat2 = ""; string userid = "admin"; string pm = ""; string batch = ""; string gh = ""; string SetValue; string insertgh; string sdwd_t = ""; string sjwd1_t = ""; string sjwd2_t = ""; string yali_t = ""; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; tkdat1 = DateTime.Now.ToString(); tkdat2 = DateTime.Now.ToString(); gh = obj_gh.Substring(0, 4).ToUpper(); yali_t = MainForm.pMainWin.yl[Convert.ToInt32(device) - 1]; sdwd_t = MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1]; sjwd1_t = MainForm.pMainWin.sjwd1[Convert.ToInt32(device) - 1]; sjwd2_t = MainForm.pMainWin.sjwd2[Convert.ToInt32(device) - 1]; SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "','" + yali_t + "','" + sdwd_t + "','" + sjwd1_t + "','" + op_t + "','" + sjwd2_t + "')"; insertgh = "insert into wd (pm,gh,batch,tkdat1,tkdat2,userid,finish,yl,sdwd,sjwd1,op,sjwd2) values " + SetValue; try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MainForm.pMainWin.ls_IniFile.WriteLog("write1", ex.Message.ToString()); return; } } private void button6_Click(object sender, EventArgs e) { DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否執行操做" + "\r"); if (result == DialogResult.No) { return; } MainForm.pMainWin.sdwd[Convert.ToInt32(device) - 1] = sd_wd.Text; } private void pictureBox1_Click(object sender, EventArgs e) { } private void button7_Click(object sender, EventArgs e) { string tkdat1 = DateTime.Now.ToString(); string tkdat2 = DateTime.Now.ToString(); string userid = "admin"; string pm = cb_pm.Text; string batch = tb_batch.Text; string gh = obj_gh.Substring(0, 4).ToUpper(); string SetValue = "('" +pm+"','"+gh+"','"+batch+"','"+tkdat1+"','"+tkdat2+"','"+userid+"','"+"1"+ "')"; ; string insertgh = "insert into gh (pm,gh,batch,tkdat1,tkdat2,userid,finish) values " + SetValue; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; string updategh = "update gh set tkdat2='" + tkdat2 + "'," + " finish ='0',"+ "userid='" + userid + "' where gh ='" + gh + "'"; string selectgh = " select count(gh) from gh where gh = '" + gh + "'" + " and finish='" +"1"+ "'"; string count=""; DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否執行操做" + "\r"); if (result == DialogResult.No) { return; } try { count = Narnu.GetObjectByOleDbString(selectgh).ToString(); } catch(Exception ex) { MessageBox.Show("出錯!" +ex.ToString()); return; } // MessageBox.Show(count.ToString()); if (count == "0") { try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MessageBox.Show("保存數據出現錯誤0!" + ex.ToString()); return; } } else { try { Narnu.DoOleDbString(updategh); } catch (Exception ex) { MessageBox.Show("保存數據出現錯誤1!" + ex.ToString()); return; } try { Narnu.DoOleDbString(insertgh); } catch (Exception ex) { MessageBox.Show("保存數據出現錯誤2!" + ex.ToString()); return; } } MessageBox.Show("操做成功!"); } private void bt_com_Click(object sender, EventArgs e) { string tkdat1 = DateTime.Now.ToString(); string tkdat2 = DateTime.Now.ToString(); string userid = "admin"; string pm = cb_pm.Text; string batch = tb_batch.Text; string gh = obj_gh.Substring(0, 4).ToUpper(); string SetValue = "('" + pm + "','" + gh + "','" + batch + "','" + tkdat1 + "','" + tkdat2 + "','" + userid + "','" + "1" + "')"; ; string insertgh = "insert into gh (pm,gh,batch,tkdat1,tkdat2,userid,finish) values " + SetValue; //string updategh = "update gh set " + "pm ='" + pm + "'," + "gh='" + gh + "'," + "batch='" + batch + "'," + "tkdat1='" + tkdat1 + "'," + "tkdat2='" + tkdat2 + "'," + "userid='" + userid + "' where gh ='" +gh + "'"; string updategh = "update gh set tkdat2='" + tkdat2 + "'," + " finish ='0'," + "userid='" + userid + "' where gh ='" + gh + "'"; string selectgh = " select count(gh) from gh where gh = '" + gh + "'" + " and finish='" + "1" + "'"; DialogResult result = MainForm.pMainWin.ls_IniFile.ShowDeleteAlert("是否執行操做" + "\r"); if (result == DialogResult.No) { return; } try { Narnu.DoOleDbString(updategh); } catch (Exception ex) { MessageBox.Show("保存數據出現錯誤1!" + ex.ToString()); return; } MessageBox.Show("操做成功!"); } private void button7_Click_1(object sender, EventArgs e) { string gh = ""; lb_gh.Text = obj_gh.Substring(0, 4).ToUpper(); gh = obj_gh.Substring(0, 4).ToUpper(); device = obj_gh.Substring(5, 2); DateTime tk; DataSet ds; tk = Convert.ToDateTime(dateTimePicker1.Value); string selectgh = " select * from gh where gh = '" + gh + "'" + " and tkdat1>=Cdate('" +tk +"')"+ " and finish='" + "1" + "' order by tkdat1 desc"; ds = Narnu.GetDataSetByOleDbString(selectgh); if (ds.Tables["gh"].Rows.Count == 0) { cb_pm.Text = ""; tb_batch.Text = ""; bt_st.Enabled = true; bt_com.Enabled = false; //cb_pm } else { cb_pm.Text = ds.Tables["gh"].Rows[0][6].ToString(); tb_batch.Text = ds.Tables["gh"].Rows[0][5].ToString(); bt_st.Enabled = false; bt_com.Enabled = true; } FillDataTk(gh.ToString(),tk); } private void button8_Click(object sender, EventArgs e) { PrintDGV.Print_DataGridView(this.dataGridView1); } } }
主要控制程序部分code
1 using System; 2 using System.Collections.Generic; 3 using System.ComponentModel; 4 using System.Data; 5 using System.Drawing; 6 using System.Linq; 7 using System.Text; 8 using System.Windows.Forms; 9 using System.Net; 10 using System.Net.Sockets; 11 using System.Data.SqlClient; 12 using System.Data.Sql; 13 using System.Data.OleDb; 14 using System.Reflection; 15 using System.Threading; 16 using System.Runtime.InteropServices; 17 using LBSoft.IndustrialCtrls; 18 using LBSoft.IndustrialCtrls.Meters; 19 using LBSoft.IndustrialCtrls.Utils; 20 21 22 namespace work 23 { 24 public partial class FormNew : Form 25 { 26 public static FormNew pMainWin = null; 27 28 public Plc objPlc = new Plc(); 29 public PlcSyn objPlc1 = new PlcSyn(); 30 public IniFile ls_IniFile = new IniFile(Environment.CurrentDirectory + "\\log.ini"); 31 public Data objData = new Data(); 32 public Mutex mutex; 33 public string ddj1read = ""; 34 public Thread objThread; 35 36 public string[] sdwd = new string[12];//設定 37 public string[] sjwd1 = new string[12];//高位 38 public string[] sjwd2 = new string[12];//低位 39 public string[] yl = new string[12];//壓力 40 public int[] k_dj = new int[3]; 41 public int[] guzhangshuru = new int[12]; 42 public int[] jiaoban = new int[19];//拌 43 public int[] zhileng = new int[12];//製冷 44 public int[] zhuangtai = new int[12]; 45 public int[] chishu = new int[12]; 46 public int[] op = new int[12]; 47 public string[] opdesc = new string[12]; 48 public Thread objReadwdThread; 49 public Thread objReadkzThread; 50 public Thread objFlashztThread; 51 public int[] jb_time = new int[12]; 52 public int[] sdjb_time = new int[12]; 53 54 public int[] zl_time = new int[12]; 55 public int[] flag_30 = new int[12]; 56 public int[] flag_60 = new int[12]; 57 public int[] flag_180 = new int[12]; 58 public int[] flag_10 = new int[12]; 59 public int[] time = new int[12]; 60 public int[] time_flag = new int[12]; 61 public int[] time_zl = new int[12]; 62 public int[] time_zl_flag = new int[12]; 63 public int[] start = new int[12]; 64 public int[] opplc = new int[12]; 65 public int flag42; 66 public int flag43; 67 public int flag44; 68 public string[] pm = new string[12];//壓力 69 public string[] batch = new string[12];//壓力 70 public string[] tkdat = new string[12];//壓力 71 public string gs_userid = ""; 72 public int[] zhileng_temp = new int[12];//製冷 73 74 public int[] op_jb_flag = new int[12]; 75 public int[] op_jb_time = new int[12]; 76 public FormNew(string userid) 77 { 78 79 InitializeComponent(); 80 pMainWin = this; 81 mutex = new Mutex(false, "SINGLE_INSTANCE_MUTEX"); 82 if (!mutex.WaitOne(0, false)) 83 { 84 mutex.Close(); 85 mutex = null; 86 } 87 this.gs_userid = userid; 88 } 89 //判斷一個子窗體是否存在 90 private bool checkChildFrmExist(string childFrmName) 91 { 92 foreach (Form childFrm in this.MdiChildren) 93 { 94 //用子窗體的Name進行判斷,若是已經存在則將他激活 95 if (childFrm.Name == childFrmName) 96 { 97 if (childFrm.WindowState == FormWindowState.Minimized) 98 childFrm.WindowState = FormWindowState.Normal; 99 childFrm.Activate(); 100 return true; 101 } 102 } 103 return false; 104 } 105 public void readwd() 106 { 107 int device = 0; 108 string dev_desc = ""; 109 while (true) 110 { 111 112 try 113 { 114 for (int i = 0; i < 11; i++) 115 { 116 device = 57 + i * 2; 117 118 if (i == 11) 119 { 120 sjwd1[i] = (Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) / 65535 * 50 - 20 + 0.5).ToString("F2"); 121 } 122 if (i == 13) 123 { 124 sjwd1[i] = (Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) / 65535 * 50 - 20 + 0.5).ToString("F2"); 125 } 126 if (i == 14) 127 { 128 sjwd1[i] = (Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) / 65535 * 50 - 20 + 0.5).ToString("F2"); 129 } 130 else 131 { 132 sjwd1[i] = (Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) / 65535 * 50 - 20 + 0.2).ToString("F2"); 133 } 134 if (i < 9) 135 { 136 dev_desc = "0" + (i + 1).ToString(); 137 // ii01_011.Text = sjwd1[0]; 138 } 139 else 140 { 141 dev_desc = (i + 1).ToString(); 142 } 143 if (op[i] == 0) 144 { 145 opdesc[i] = "手動"; 146 } 147 if (op[i] == 1) 148 { 149 opdesc[i] = "自動"; 150 } 151 if (op[i] == 2) 152 { 153 opdesc[i] = "澄清"; 154 } 155 if (op[i] == 3) 156 { 157 opdesc[i] = "發酵"; 158 } 159 ii01_014.Text = opdesc[0]; 160 ii02_024.Text = opdesc[1]; 161 ii03_034.Text = opdesc[2]; 162 ii04_044.Text = opdesc[3]; 163 ii05_054.Text = opdesc[4]; 164 ii06_064.Text = opdesc[5]; 165 ii07_074.Text = opdesc[6]; 166 ii08_084.Text = opdesc[7]; 167 ii09_094.Text = opdesc[8]; 168 ii10_104.Text = opdesc[9]; 169 ii11_114.Text = opdesc[10]; 170 171 172 ii01_012.Text = sjwd1[0]; 173 ii02_022.Text = sjwd1[1]; 174 ii03_032.Text = sjwd1[2]; 175 ii04_042.Text = sjwd1[3]; 176 ii05_052.Text = sjwd1[4]; 177 ii06_062.Text = sjwd1[5]; 178 ii07_072.Text = sjwd1[6]; 179 ii08_082.Text = sjwd1[7]; 180 ii09_092.Text = sjwd1[8]; 181 ii10_102.Text = sjwd1[9]; 182 ii11_112.Text = sjwd1[10]; 183 184 // 185 ii01_011.Text = sdwd[0]; 186 ii02_021.Text = sdwd[1]; 187 ii03_031.Text = sdwd[2]; 188 ii04_041.Text = sdwd[3]; 189 ii05_051.Text = sdwd[4]; 190 ii06_061.Text = sdwd[5]; 191 ii07_071.Text = sdwd[6]; 192 ii08_081.Text = sdwd[7]; 193 ii09_091.Text = sdwd[8]; 194 ii10_101.Text = sdwd[9]; 195 ii11_111.Text = sdwd[10]; 196 197 //System.Windows.Forms.TextBox tb = (System.Windows.Forms.TextBox); 198 //FormDisplay FormDisplay = new FormDisplay(pb.Name); 199 //FormDisplay.Show(); 200 // sf01_011.Text = sdwd[0].ToString(); 201 // sf01_012.Text = sjwd1[0].ToString(); 202 //sf01_013.Text = sjwd2[0].ToString(); 203 // sf01_014.Text = yl[0].ToString(); 204 } 205 206 for (int j = 0; j < 11; j++) 207 { 208 device = 58 + j * 2; 209 yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 3.8/ 65535) * 5).ToString("F2"); 210 if ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 3.9 / 65535) > 4.1) 211 { 212 yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 3.8/ 65535 - 3.9) * 5 / 4 + 3.8 * 5).ToString("F2"); 213 } 214 else 215 { 216 yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 3.8 / 65535) * 5).ToString("F2"); 217 } 218 219 // 220 //if ((Convert.ToDouble(objPlc1.ReadPlc("77")) * 13 / 65535) > 11) 221 //{ 222 // yl[1] = (((Convert.ToDouble(objPlc1.ReadPlc("77")) * 13 / 65535) - 11) * 20 / 3 + 11 * 23.2 + 0.4).ToString("F2"); 223 //} 224 //else 225 //{ 226 // yl[1] = ((Convert.ToDouble(objPlc1.ReadPlc("77")) * 13 / 65535) * 23.2 + 0.4).ToString("F2"); 227 //} 228 //if (j == 0) 229 //{ 230 // yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 4.1 / 65535) * 5.51).ToString("F2"); 231 //} 232 233 //if (j == 25) 234 //{ 235 // if ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 4.5 / 65535) > 11) 236 // { 237 // yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 4.5 / 65535) * 5.61).ToString("F2"); 238 // } 239 //} 240 241 //if (j == 26) 242 //{ 243 // yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 4.5 / 65535) * 5.5).ToString("F2"); 244 //} 245 //if (j == 35) 246 //{ // yl[j] = ((Convert.ToDouble(objPlc1.ReadPlc(device.ToString())) * 4.5 / 65535) * 5.5).ToString("F2"); 247 //} 248 ii01_013.Text = yl[0]; 249 ii02_023.Text = yl[1]; 250 ii03_033.Text = yl[2]; 251 ii04_043.Text = yl[3]; 252 ii05_053.Text = yl[4]; 253 ii06_063.Text = yl[5]; 254 ii07_073.Text = yl[6]; 255 ii08_083.Text = yl[7]; 256 ii09_093.Text = yl[8]; 257 ii10_103.Text = yl[9]; 258 ii11_113.Text = yl[10]; 259 260 } 261 262 for (int k = 0; k < 11; k++) 263 { 264 device = 19 + k; 265 zhileng[k] = Convert.ToInt32(objPlc1.ReadPlc(device.ToString())); 266 } 267 268 for (int m = 0; m < 18; m++) 269 { 270 device = 1 + m; 271 jiaoban[m] = Convert.ToInt32(objPlc1.ReadPlc(device.ToString())); 272 } 273 274 //for (int n = 0; n < 41; n++) 275 //{ 276 // device = 89 + n; 277 // guzhangshuru[n] = Convert.ToInt32(objPlc1.ReadPlc(device.ToString())); 278 //} 279 //for (int n = 0; n < 3; n++) 280 //{ 281 // device = 83 + n; 282 // k_dj[n] = Convert.ToInt32(objPlc1.ReadPlc(device.ToString())); 283 //} 284 Thread.Sleep(200); 285 } 286 catch (Exception e) 287 { 288 //ls_IniFile.WriteLog("ReadData12", e.Message.ToString()); 289 continue; 290 } 291 292 } 293 } 294 private string DateDiff(DateTime DateTime1, DateTime DateTime2) 295 { 296 string dateDiff = null; 297 try 298 { 299 TimeSpan ts1 = new TimeSpan(DateTime1.Ticks); 300 TimeSpan ts2 = new TimeSpan(DateTime2.Ticks); 301 TimeSpan ts = ts1.Subtract(ts2).Duration(); 302 dateDiff = ts.Days.ToString() + "天" 303 + ts.Hours.ToString() + "時" 304 + ts.Minutes.ToString() + "分"; 305 //+ ts.Seconds.ToString() + "秒"; 306 } 307 catch 308 { 309 310 } 311 return dateDiff; 312 }
儀表顯示控件源碼 http://files.cnblogs.com/files/meslog/LBIndustrialCtrls_src.zip qq 1153755352orm