aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs
diff options
context:
space:
mode:
authorRoy Ben-Shabat <Roy@Twine-s.com>2018-01-16 12:17:10 +0200
committerRoy Ben-Shabat <Roy@Twine-s.com>2018-01-16 12:17:10 +0200
commit0fda2ba3ff49bdc1ffc6833f658e2164af187008 (patch)
tree6f3a24d0671ebda50debb8511ab40e0bda0a0df0 /Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs
parent28103646681686bf1b58275d5dbccb92d2b26f9f (diff)
downloadTango-0fda2ba3ff49bdc1ffc6833f658e2164af187008.tar.gz
Tango-0fda2ba3ff49bdc1ffc6833f658e2164af187008.zip
Embedded RealTimeGraphEx library to solution.
Added graphs to technician view. Implemented simple sensors data test using Machine Emulator.
Diffstat (limited to 'Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs')
-rw-r--r--Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs229
1 files changed, 229 insertions, 0 deletions
diff --git a/Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs b/Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs
new file mode 100644
index 000000000..8693e31db
--- /dev/null
+++ b/Software/Visual_Studio/SideChains/RealTimeGraphEx/ReachGraphs/RealTimeGraphExReachMultiLineScroll.cs
@@ -0,0 +1,229 @@
+using RealTimeGraphEx.Controllers;
+using RealTimeGraphEx.Models;
+using System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using System.Windows;
+using System.Windows.Media;
+using System.Windows.Media.Imaging;
+using System.Windows.Shapes;
+using System.Windows.Threading;
+
+namespace RealTimeGraphEx.ReachGraphs
+{
+ public class RealTimeGraphExReachMultiLineScroll : RealTimeGraphExMultiBase
+ {
+ #region Cross Thread Fields
+
+ protected List<RealTimeGraphExReachPolygon> _graphPolygons;
+ protected List<Polygon> polygons;
+ protected Brush _stroke;
+ protected Brush _fill;
+ protected bool _fillGraph;
+
+ #endregion
+
+ #region Constructors
+
+ public RealTimeGraphExReachMultiLineScroll()
+ : base()
+ {
+ _graphPolygons = new List<RealTimeGraphExReachPolygon>();
+ _graphController = new GraphMultiController();
+ polygons = new List<Polygon>();
+ }
+
+ #endregion
+
+ #region Properties
+
+ /// <summary>
+ /// Gets or sets the graph strokes color.
+ /// </summary>
+ public Brush Stroke
+ {
+ get { return (Brush)GetValue(StrokeProperty); }
+ set { SetValue(StrokeProperty, value); }
+ }
+ public static readonly DependencyProperty StrokeProperty =
+ DependencyProperty.Register("Stroke", typeof(Brush), typeof(RealTimeGraphExReachMultiLineScroll), new PropertyMetadata(Brushes.Black, new PropertyChangedCallback(CrossModelChanged)));
+
+ /// <summary>
+ /// Gets or sets the graph fill color.
+ /// </summary>
+ public Brush Fill
+ {
+ get { return (Brush)GetValue(FillProperty); }
+ set { SetValue(FillProperty, value); }
+ }
+ public static readonly DependencyProperty FillProperty =
+ DependencyProperty.Register("Fill", typeof(Brush), typeof(RealTimeGraphExReachMultiLineScroll), new PropertyMetadata(null, new PropertyChangedCallback(CrossModelChanged)));
+
+ /// <summary>
+ /// Gets or sets whether the graph will be rendered using the Fill color property.
+ /// </summary>
+ public bool FillGraph
+ {
+ get { return (bool)GetValue(FillGraphProperty); }
+ set { SetValue(FillGraphProperty, value); }
+ }
+ public static readonly DependencyProperty FillGraphProperty =
+ DependencyProperty.Register("FillGraph", typeof(bool), typeof(RealTimeGraphExReachMultiLineScroll), new PropertyMetadata(false, new PropertyChangedCallback(CrossModelChanged)));
+
+ #endregion
+
+ #region Override Methods
+
+ protected override void OnControllerChanged()
+ {
+ if (_graphController != null)
+ {
+ _graphController.RegisterMethods(ClearGraph, StartPushThread, SetPaused, ChangeRenderMode, null);
+ polygons.Clear();
+ gridLinesAndImageWrapperGrid.Children.Remove(img);
+
+ foreach (var dataSeries in _graphController.DataSeriesCollection)
+ {
+ _graphPolygons.Add(new RealTimeGraphExReachPolygon());
+ Polygon polygon = new Polygon();
+ polygons.Add(polygon);
+ gridLinesAndImageWrapperGrid.Children.Add(polygon);
+ }
+ }
+ }
+
+ protected override void OnSizeChanged(object sender, SizeChangedEventArgs e)
+ {
+ OnSetCrossThreadFields();
+ }
+
+ protected override void OnSetCrossThreadFields()
+ {
+ base.OnSetCrossThreadFields();
+
+ this.Dispatcher.Invoke(() =>
+ {
+ _maxPoints = MaxPoints;
+ _scaleFactor = _width / _maxPoints;
+ _graphController = Controller;
+ _stroke = Stroke;
+ _fill = Fill;
+
+ if (_graphController != null && _graphController.dataSeriesCollection != null && _graphController.dataSeriesCollection.Count > 0)
+ {
+ for (int i = 0; i < _graphController.dataSeriesCollection.Count; i++)
+ {
+ polygons[i].Fill = _graphController.dataSeriesCollection[i].fill;
+ polygons[i].Stroke = _graphController.dataSeriesCollection[i].stroke;
+ polygons[i].Margin = new Thickness(-2, 1, -2, 0);
+ }
+ }
+
+
+
+ }, System.Windows.Threading.DispatcherPriority.Send);
+ }
+
+ protected override void OnClearGraph()
+ {
+ _graphPolygons.ForEach(x => x.ClearPoints());
+ _graphPolygons.ForEach(x => x.ClearActualPoints());
+
+ this.Dispatcher.Invoke(() =>
+ {
+ foreach (var polygon in polygons)
+ {
+ polygon.Points.Clear();
+ }
+ });
+
+ base.OnClearGraph();
+ }
+
+ protected internal override void OnRenderGraph()
+ {
+ if (_graphController != null && _graphController.dataSeriesCollection.Count > 0 && _graphController.TotalPoints > 0 && _width > 1 && _height > 1)
+ {
+ for (int i = 0; i < _graphController.dataSeriesCollection.Count; i++)
+ {
+ double seriesCounter = xValueCounter;
+
+
+ for (int j = 0; j < _graphController.dataSeriesCollection[i].Points.Count; j++)
+ {
+ double value = _graphController.dataSeriesCollection[i].Points[j];
+
+ double valuePrecentage = value;
+
+ _graphPolygons[i].Add(seriesCounter, valuePrecentage, value);
+ seriesCounter += _scaleFactor;
+ }
+ }
+
+ for (int i = 0; i < _graphController.dataSeriesCollection[0].Points.Count; i++)
+ {
+ xValueCounter += _scaleFactor;
+ }
+
+ if (_graphPolygons[0].TotalPoints > _maxPoints + _graphController.dataSeriesCollection[0].Points.Count)
+ {
+ xValueCounter -= (_scaleFactor * (_graphPolygons[0].TotalPoints - (_maxPoints + _graphController.dataSeriesCollection[0].Points.Count)));
+
+ foreach (var polygon in _graphPolygons)
+ {
+ polygon.RemoveFromStart(polygon.TotalPoints - (_maxPoints + _graphController.dataSeriesCollection[0].Points.Count));
+ }
+ }
+
+
+ updateCounter++;
+
+ if (updateCounter >= 1)
+ {
+ updateCounter = 0;
+
+ if (!_isPaused)
+ {
+ OnDrawVisuals();
+ }
+ }
+ }
+ }
+
+ #endregion
+
+ #region Virtual Methods
+
+ protected virtual void OnDrawVisuals()
+ {
+ for (int i = 0; i < _graphPolygons.Count; i++)
+ {
+ var polygon = _graphPolygons[i];
+ double scale = _width / (polygon.TotalPoints - 1);
+
+ if (polygon.Points.Count > 0)
+ {
+ if (_graphController.dataSeriesCollection[i].isVisible) //Fill Graph
+ {
+ this.Dispatcher.Invoke(() =>
+ {
+ polygons[i].Points = new PointCollection(polygon.ToPolygonPointsFill(_width, _height, scale, ConvertYToImageYFliped));
+
+ }, DispatcherPriority.Send);
+ }
+ else
+ {
+ this.Dispatcher.Invoke(() =>
+ {
+ polygons[i].Points.Clear();
+ }, DispatcherPriority.Send);
+ }
+ }
+ }
+ }
+
+ #endregion
+ }
+}