Beispiel #1
0
        private bool Execute1s()
        {
            //Console.WriteLine("1s");
            DT = new DateTime();
            if (clientStan.GetPlcDateTime(ref DT) == 0)
            {
                //Console.WriteLine("Текущее время PLC -> " + DT.ToLongDateString() + " - " + DT.ToLongTimeString());
                //Console.WriteLine("Текущее время PLC -> " + DT.ToShortDateString() + " - " + DT.ToLongTimeString());
                Console.WriteLine("Текущее время PLC -> " + DT.ToString("yyyy-MM-dd HH:mm:ss.fff"));
            }

            #region DB100
            var buffer    = new byte[20];
            int readDB100 = clientStan.DBRead(100, 82, buffer.Length, buffer);
            if (readDB100 == 0)
            {
                //Console.WriteLine("readDB100 read ok");

                float db100dbb82_s4 = S7.GetRealAt(buffer, 0);
                float db100dbb86_s5 = S7.GetRealAt(buffer, 4);
                float db100dbb90_s3 = S7.GetRealAt(buffer, 8);
                float db100dbb94_s2 = S7.GetRealAt(buffer, 12);
                speed4kl = db100dbb82_s4;
                float db100dbb98_s1 = S7.GetRealAt(buffer, 16);

                //Console.WriteLine("1 = " + db100dbb98_s1.ToString("F"));
                //Console.WriteLine("2 = " + db100dbb94_s2.ToString("F"));
                //Console.WriteLine("3 = " + db100dbb90_s3.ToString("F"));
                //Console.WriteLine("4 = " + db100dbb82_s4.ToString("F"));
                //Console.WriteLine("5 = " + db100dbb86_s5.ToString("F"));

                //System.Diagnostics.Trace.WriteLine("4 кл = " + speed4kl.ToString("F"));
            }
            else
            {
                Console.WriteLine("readDB100 read error");
                System.Diagnostics.Trace.WriteLine(DateTime.Now.ToString() + " -- DB100 read error");
                return(false);
            }
            #endregion

            #region DB101
            var bufferDB101 = new byte[4];
            int readDB101   = clientStan.DBRead(101, 4, bufferDB101.Length, bufferDB101);
            if (readDB101 == 0)
            {
                //Console.WriteLine("readDB101 read ok");

                float db101dbd4_h5Work = S7.GetRealAt(bufferDB101, 0);
                h5w = db101dbd4_h5Work;
                // Console.WriteLine("H5 work = " + db101dbd4_h5Work.ToString("F"));

                //System.Diagnostics.Trace.WriteLine("H5 work = " + H5_work.ToString("F"));
            }
            else
            {
                Console.WriteLine("readDB101 read error");
                System.Diagnostics.Trace.WriteLine(DateTime.Now.ToString() + " -- DB101 read error");
                return(false);
            }
            #endregion

            #region MD316
            var bufferMD316 = new byte[4];
            int readMD316   = clientStan.MBRead(316, bufferMD316.Length, bufferMD316);
            if (readMD316 == 0)
            {
                //Console.WriteLine("readMD316 read ok");

                float md316_D_tek_mot = S7.GetRealAt(bufferMD316, 0);
                D_tek_mot = md316_D_tek_mot;
                //Console.WriteLine("H5 work = " + md316_D_tek_mot.ToString("F"));

                //System.Diagnostics.Trace.WriteLine("D_tek_mot= " + D_tek_mot.ToString("F"));
            }
            else
            {
                Console.WriteLine("readMD316 read error");
                System.Diagnostics.Trace.WriteLine(DateTime.Now.ToString() + " -- MD316 read error");
                return(false);
            }
            #endregion

            #region DB105
            var bufferDB105 = new byte[4];
            int readDB105   = clientStan.DBRead(105, 20, bufferDB105.Length, bufferDB105);
            if (readDB105 == 0)
            {
                //Console.WriteLine("readDB105 read ok");

                float db105dbd20_B_Work = S7.GetRealAt(bufferDB105, 0);
                Bw = db105dbd20_B_Work;
                //Console.WriteLine("H5 work = " + db105dbd20_B_Work.ToString("F"));

                //System.Diagnostics.Trace.WriteLine("B work = " + B_Work.ToString("F"));
            }
            else
            {
                Console.WriteLine("readDB105 read error");
                System.Diagnostics.Trace.WriteLine(DateTime.Now.ToString() + " -- DB105 read error");
                return(false);
            }
            #endregion

            #region  асчет параметров прокатанного рулона после окончания прокатки

            if (D_tek_mot > D_pred_mot)
            {
                if (D_pred_mot < 0.615)
                {
                    Time_Start = DT;
                }
            }

            if ((Time_Start != new DateTime()) && (H5_work == 0) && (D_tek_mot > 0.7) && (speed4kl > 2))
            {
                H5_work = h5w;
                B_Work  = Bw;
            }

            //Console.WriteLine("Time_Start="+ Time_Start.ToString());
            //Console.WriteLine("Time_Stop=" + Time_Stop.ToString());
            //Console.WriteLine("D_tek_mot=" + D_tek_mot);
            //Console.WriteLine("Speed 4kl=" + speed4kl);
            //Console.WriteLine("H5_work=" + H5_work);
            //Console.WriteLine("B_Work=" + B_Work);



            if ((Time_Start != new DateTime()) && (H5_work != 0) && (D_tek_mot < 0.610) && (D_tek_mot < D_pred_mot))
            {
                Ves_Work  = (((((D_pred_mot * D_pred_mot) - 0.36F) * 3.141593F) / 4) * (B_Work / 1000)) * 7.85F;
                Time_Stop = DT;

                Dlina_Work = ((Ves_Work / 7.85F) / (B_Work / 1000)) / (H5_work / 1000);


                //System.Diagnostics.Trace.WriteLine("Начало прокатки рулона = " + Time_Start.ToString());
                //System.Diagnostics.Trace.WriteLine("Окончание прокатки рулона = " + Time_Stop.ToString());
                //System.Diagnostics.Trace.WriteLine("Bес рулона = " + Ves_Work.ToString("F"));
                //System.Diagnostics.Trace.WriteLine("Длинна рулона = " + Dlina_Work.ToString("F"));


                #region Передаем в Базу Данных

                //yyyy - MM - dd HH: mm: ss.fff
                string strTimeStart = Time_Start.ToString("yyyy-MM-dd HH:mm:ss.fff");
                string strTimeStop  = Time_Stop.ToString("yyyy-MM-dd HH:mm:ss.fff");

                string sql_1secQuery = "INSERT INTO stanm_proiz (dtcontrollerstart, dtcontrollerstop, ves, dlinna, h5, b, speed4kl) VALUES ('" + strTimeStart + "', '" + strTimeStop + "', " + Ves_Work + ", " + Dlina_Work + ", " + H5_work + ", " + B_Work + ", " + speed4kl + ")";
                Console.WriteLine(sql_1secQuery);

                SQLCom = new SqlCommand(sql_1secQuery, SQLCon);
                int number = SQLCom.ExecuteNonQuery();
                Console.WriteLine("Добавлено объектов {0}", number);

                #endregion



                H5_work    = 0; B_Work = 0; Ves_Work = 0; Dlina_Work = 0;
                Time_Start = new DateTime();
                Time_Stop  = new DateTime();
            }

            D_pred_mot = D_tek_mot;

            #endregion

            return(true);
        }