示例#1
0
 internal DataToVisualize(TelegramHead telHead, MeasuredHead measuredHead, MeasuredData measuredData,
                          double convTime, double saveTime)
 {
     m_telHead      = telHead;
     m_measuredHead = measuredHead;
     m_measuredData = measuredData;
     m_convTimeSpan = convTime;
     m_saveTimeSpan = saveTime;
 }
示例#2
0
        /// <summary> adds a row to the transient measure table of the meant database </summary>
        /// <param name="h_idx"> the foreign key to insert </param>
        /// <param name="measData"> the data </param>
        private void addRowsMeasure(System.Int32 h_idx, MeasuredData measData)
        {
            int idx = (int)m_ActiveDB;

            if (idx == 0)
            {
                return;
            }
            else
            {
                ((DBInterface)(m_dataBases[idx])).addRowToMeasureTable(h_idx, measData);
            }
        }
示例#3
0
        /// <summary> adds a new row to the transient datatable "measure" </summary>
        /// <param name="h_idx"> the foreign key (must be the PK of the "heater" table) </param>
        /// <param name="measData"> the converted data delivered from the datachange event </param>
        public void addRowToMeasureTable(System.Int32 h_idx, MeasuredData measData)
        {
            // remove the first row, if there are more than 5 datasets

            // 找不到XMLDB类  lhc171221
            //if (m_XMLDB.Measure.Rows.Count >= (RECORDS_TO_SAVE + 1) * RECORDS_PER_HEATER)
            //{
            //    m_XMLDB.Measure.Rows.RemoveAt(0);
            //}
            //DataRow row = m_XMLDB.Measure.NewRow();
            //row["H_idx"] = h_idx;
            //row["M_id"] = measData.dataMeasurepointIndex;
            //row["Temp"] = measData.dataTemperature;
            //row["Pressure"] = measData.dataPressure;
            //row["Flow"] = measData.dataFlow;
            //row["Humidity"] = measData.dataHumidity;
            //row["M_desc"] = measData.dataDescription;
            //m_XMLDB.Measure.Rows.Add(row);
        }
 /// <summary> adds a new row to the transient datatable "measure" </summary>
 /// <param name="h_idx"> the foreign key (must be the PK of the "heater" table) </param>
 /// <param name="measData"> the converted data delivered from the datachange event </param>
 public void addRowToMeasureTable(System.Int32 h_idx, MeasuredData measData)
 {
     if (!m_disposed)
     {
         DataRow row = m_dtMeasure.NewRow();
         row["H_idx"]    = h_idx;
         row["M_id"]     = measData.dataMeasurepointIndex;
         row["Temp"]     = System.Math.Round((decimal)(measData.dataTemperature), 4);
         row["Pressure"] = System.Math.Round((decimal)(measData.dataPressure), 4);
         row["Flow"]     = System.Math.Round((decimal)(measData.dataFlow), 4);
         row["Humidity"] = System.Math.Round((decimal)(measData.dataHumidity), 4);
         row["M_desc"]   = measData.dataDescription;
         m_dtMeasure.Rows.Add(row);
     }
     else
     {
         throw new Exception("Object has been disposed!");
     }
 }
示例#5
0
        /// <summary>  sets the value delivered from ondatachange </summary>
        /// <param name="theValue"> the value (must be byte array) </param>
        /// <exception cref="InvalidCastException"> if the value cannot be converted into a byte array </exception>
        /// <remarks> NOTES:
        /// - this methods measures the time for converting and saving to DB
        /// - it is recommended to call this method asynchronously, because saving to DB may take several seconds </remarks>
        public void setOPCParam(object theValue)
        {
            TelegramHead telHead      = null;
            MeasuredHead measHeadVisu = null;
            MeasuredData measDataVisu = null;

            // Take time for converting
            StopWatch convStopWatch = new StopWatch(TimerType.PerformanceCounter);

            convStopWatch.Scale = 1000.0;
            convStopWatch.Start();

            // Take time for saving
            StopWatch saveStopWatch = new StopWatch(TimerType.PerformanceCounter);

            saveStopWatch.Scale = 1000.0;

            // Convert data
            S7DataConverter theData;

            byte[] data = null;
            try
            {
                data    = (byte[])theValue;
                theData = new S7DataConverter(data, true, true);
            }
            catch (InvalidCastException ex)
            {
                // forward the exception
                throw ex;
            }

            int offset = 0;

            // read telegram-header
            telHead = readOutTelegramHead(theData, data.Length, ref offset);

            // read out data
            readOutData(theData, telHead.telNumberRecords, ref offset, out measHeadVisu, out measDataVisu);
            convStopWatch.Stop();

            // Now save update the database
            try
            {
                saveStopWatch.Start();
                int idx = (int)m_ActiveDB;
                if (idx != 0)
                {
                    ((DBInterface)(m_dataBases[idx])).Insert();
                }
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                saveStopWatch.Stop();

                // Fill the data for visualization
                DataToVisualize dataToVisu = new DataToVisualize(telHead, measHeadVisu, measDataVisu,
                                                                 convStopWatch.Time, saveStopWatch.Time);

                // fire the event, that saving is completed
                OnBRCVOccured(this, dataToVisu);
            }
        }
示例#6
0
        /// <summary>  converts a part (measured data) of the byte array into C# types for further usage  </summary>
        /// <param name="theData"> the byte array </param>
        /// <param name="telNumberRecords"> the number of records (delivered via the telegram head) </param>
        /// <param name="offset">  offset needed to convert the data  </param>
        /// <param name="measHeadVisu"> the head data for visualization </param>
        /// <param name="measDataVisu">  the measured data for visualization </param>
        /// <remarks> NOTE: this method also fills the data into the meant (transient) DB; the insertion of the data
        /// into the persistent storage has to be done in calling function! </remarks>
        private void readOutData(S7DataConverter theData, int telNumberRecords, ref int offset,
                                 out MeasuredHead measHeadVisu, out MeasuredData measDataVisu)
        {
            Int16    headDataH_ID        = 0;
            DateTime headDataMeasureTime = new DateTime(2004, 12, 3);
            float    headDataPressure    = 0;
            float    headDataEnergy      = 0;
            string   headDataDescription = "";

            Int16  dataMeasurepointIndex = 0;
            float  dataTemperature       = 0;
            float  dataPressure          = 0;
            float  dataFlow        = 0;
            float  dataHumidity    = 0;
            string dataDescription = "";

            MeasuredHead measHead = null;
            MeasuredData measData = null;

            measHeadVisu = null;
            measDataVisu = null;

            for (int i = 0; i < telNumberRecords; i++)
            {
                // read data-header
                offset = theData.GetValue(offset, S7Types.INT, ref headDataH_ID);
                offset = theData.GetValue(offset, S7Types.DATE_AND_TIME, ref headDataMeasureTime);
                offset = theData.GetValue(offset, S7Types.REAL, ref headDataPressure);
                offset = theData.GetValue(offset, S7Types.REAL, ref headDataEnergy);
                offset = theData.GetValue(offset, S7Types.STRING, ref headDataDescription);
                // adjust offset manually! The string has 10 characters.
                offset += 10;

                System.Int32 h_idx = 0;
                measHead = new MeasuredHead(headDataH_ID, headDataMeasureTime,
                                            headDataPressure, headDataEnergy,
                                            headDataDescription);

                // Now add the row
                h_idx = addRowsHeater(measHead);

                // read measured data
                // there are 8 measurementpoints
                for (int j = 0; j < 8; j++)
                {
                    offset = theData.GetValue(offset, S7Types.INT, ref dataMeasurepointIndex);
                    offset = theData.GetValue(offset, S7Types.REAL, ref dataTemperature);
                    offset = theData.GetValue(offset, S7Types.REAL, ref dataPressure);
                    offset = theData.GetValue(offset, S7Types.REAL, ref dataFlow);
                    offset = theData.GetValue(offset, S7Types.REAL, ref dataHumidity);
                    offset = theData.GetValue(offset, S7Types.STRING, ref dataDescription);
                    // adjust offset manually! The string has 10 characters.
                    offset += 10;

                    measData = new MeasuredData(dataMeasurepointIndex,
                                                dataTemperature, dataPressure, dataFlow,
                                                dataHumidity, dataDescription);

                    // all data is collected -> add the row
                    addRowsMeasure(h_idx, measData);

                    if (i == 0 && j == 0)
                    {
                        measHeadVisu = measHead.Clone();
                        measDataVisu = measData.Clone();
                    }
                }
            }
        }