aboutsummaryrefslogtreecommitdiffstats
path: root/Software/Visual_Studio/SideChains/RealTimeGraphEx/FastGraphs/RealTimeGraphExWaveErase.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/FastGraphs/RealTimeGraphExWaveErase.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/FastGraphs/RealTimeGraphExWaveErase.cs')
-rw-r--r--Software/Visual_Studio/SideChains/RealTimeGraphEx/FastGraphs/RealTimeGraphExWaveErase.cs79
1 files changed, 79 insertions, 0 deletions
diff --git a/Software/Visual_Studio/SideChains/RealTimeGraphEx/FastGraphs/RealTimeGraphExWaveErase.cs b/Software/Visual_Studio/SideChains/RealTimeGraphEx/FastGraphs/RealTimeGraphExWaveErase.cs
new file mode 100644
index 000000000..06ef8ffa0
--- /dev/null
+++ b/Software/Visual_Studio/SideChains/RealTimeGraphEx/FastGraphs/RealTimeGraphExWaveErase.cs
@@ -0,0 +1,79 @@
+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;
+
+namespace RealTimeGraphEx.FastGraphs
+{
+ public class RealTimeGraphExWaveErase : RealTimeGraphExLineErase
+ {
+ #region Constructors
+
+ public RealTimeGraphExWaveErase()
+ : base()
+ {
+
+ }
+
+ #endregion
+
+ #region Override Methods
+
+ /// <summary>
+ /// Set the cross thread fields.
+ /// </summary>
+ protected override void OnSetCrossThreadFields()
+ {
+ base.OnSetCrossThreadFields();
+
+ this.Dispatcher.Invoke(() =>
+ {
+
+ _minimum = _maximum * -1;
+
+ }, System.Windows.Threading.DispatcherPriority.Send);
+ }
+
+ /// <summary>
+ /// Draw the actual polygon on the image.
+ /// </summary>
+ /// <param name="bmp"></param>
+ protected override void OnDrawVisuals(WriteableBitmap bmp)
+ {
+ Color stroke = _graphController.dataSeries.GetStrokeColor() != null ? _graphController.dataSeries.GetStrokeColor().Value : _stroke;
+ Color fill = _graphController.dataSeries.GetFillColor() != null ? _graphController.dataSeries.GetFillColor().Value : _fill;
+ double scale = GetPolygonScaleFactor();
+ double currentWidth = _endReached ? _width : xValueCounter;
+
+
+ if (_fillGraph) //Fill Graph
+ {
+ bmp.FillPolygon(graphPolygon.ToPolygonPointsWaveFill(_offSetX, _offSetY, _width, _height, scale, ConvertYToImageYFliped), fill);
+ }
+
+ DrawPolyline(bmp, graphPolygon.ToPolygonPoints(_offSetX, _offSetY, scale, ConvertYToImageYFliped), stroke);
+ DrawPolyline(bmp, graphPolygon.ToPolygonPointsReflection(_offSetX, _offSetY, _height, scale, ConvertYToImageYFliped), stroke);
+
+ //Draw marker
+ if (_showMarker)
+ {
+ if (_currentReplaceIndex > 0)
+ {
+ double x = ((_currentReplaceIndex * scale) + _offSetX);
+ bmp.DrawLine((int)x, 0, (int)x, (int)_mainHeight, _markerColor);
+ }
+ }
+
+ if (_enableMarkerPosition)
+ {
+ MarkerPosition = new Point((_currentReplaceIndex * scale) + _offSetX, ConvertYToImageYFliped(lastVirtualValue) + _offSetY);
+ }
+ }
+
+ #endregion
+ }
+}