From 0fda2ba3ff49bdc1ffc6833f658e2164af187008 Mon Sep 17 00:00:00 2001 From: Roy Ben-Shabat Date: Tue, 16 Jan 2018 12:17:10 +0200 Subject: Embedded RealTimeGraphEx library to solution. Added graphs to technician view. Implemented simple sensors data test using Machine Emulator. --- .../RealTimeGraphEx/Controllers/GraphController.cs | 96 ++++++++++++++++++++++ 1 file changed, 96 insertions(+) create mode 100644 Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphController.cs (limited to 'Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphController.cs') diff --git a/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphController.cs b/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphController.cs new file mode 100644 index 000000000..81bf3b9db --- /dev/null +++ b/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphController.cs @@ -0,0 +1,96 @@ +using RealTimeGraphEx.DataSeries; +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows; + +namespace RealTimeGraphEx.Controllers +{ + public class GraphController : GraphControllerBase + { + #region Cross Thread Fields + + internal DataYSeries dataSeries; + + #endregion + + public GraphController() + { + DataSeries = new DataYSeries(); + } + + public DataYSeries DataSeries + { + get { return (DataYSeries)GetValue(DataSeriesProperty); } + set { SetValue(DataSeriesProperty, value); } + } + public static readonly DependencyProperty DataSeriesProperty = + DependencyProperty.Register("Controller", typeof(DataYSeries), typeof(GraphController), new PropertyMetadata(null, new PropertyChangedCallback(SetCrossThreadFields))); + + + + private static void SetCrossThreadFields(DependencyObject d, DependencyPropertyChangedEventArgs e) + { + (d as GraphController).OnSetCrossModelFields(); + } + + protected virtual void OnSetCrossModelFields() + { + this.Dispatcher.Invoke(() => + { + + dataSeries = DataSeries; + + }, System.Windows.Threading.DispatcherPriority.Send); + } + + public override void Clear() + { + if (clearMethod != null) + { + clearMethod(); + } + + dataSeries.ClearPoints(); + } + + internal override void ClearPoints() + { + dataSeries.ClearPoints(); + } + + public virtual void PushData(List values) + { + if (startThreadMethod != null) + { + startThreadMethod(); + } + + dataSeries.PushData(values); + } + + public virtual void PushData(double[] values) + { + if (startThreadMethod != null) + { + startThreadMethod(); + } + + dataSeries.PushData(values); + } + + public virtual void PushData(double value) + { + if (startThreadMethod != null) + { + startThreadMethod(); + } + + dataSeries.PushData(value); + } + + + } +} -- cgit v1.3.1