diff options
| author | Roy Ben-Shabat <Roy@Twine-s.com> | 2018-01-16 12:17:10 +0200 |
|---|---|---|
| committer | Roy Ben-Shabat <Roy@Twine-s.com> | 2018-01-16 12:17:10 +0200 |
| commit | 0fda2ba3ff49bdc1ffc6833f658e2164af187008 (patch) | |
| tree | 6f3a24d0671ebda50debb8511ab40e0bda0a0df0 /Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphControllerBase.cs | |
| parent | 28103646681686bf1b58275d5dbccb92d2b26f9f (diff) | |
| download | Tango-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/Controllers/GraphControllerBase.cs')
| -rw-r--r-- | Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphControllerBase.cs | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphControllerBase.cs b/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphControllerBase.cs new file mode 100644 index 000000000..c045ca03a --- /dev/null +++ b/Software/Visual_Studio/SideChains/RealTimeGraphEx/Controllers/GraphControllerBase.cs @@ -0,0 +1,62 @@ +using System; +using System.Collections.Generic; +using System.Linq; +using System.Text; +using System.Threading.Tasks; +using System.Windows; + +namespace RealTimeGraphEx.Controllers +{ + public abstract class GraphControllerBase : DependencyObject + { + protected Action clearMethod; + protected Action startThreadMethod; + protected Action<bool> pausedMethod; + protected Action<bool> changeRenderModeMethod; + protected Action pushMarkerMethod; + + public bool IsPaused + { + get { return (bool)GetValue(IsPausedProperty); } + set { SetValue(IsPausedProperty, value); } + } + public static readonly DependencyProperty IsPausedProperty = + DependencyProperty.Register("IsPaused", typeof(bool), typeof(GraphControllerBase), new PropertyMetadata(false, new PropertyChangedCallback(PausedChanged))); + + private static void PausedChanged(DependencyObject d, DependencyPropertyChangedEventArgs e) + { + var control = d as GraphControllerBase; + if (control.pausedMethod != null) + { + control.pausedMethod(control.IsPaused); + } + } + + + internal void RegisterMethods(Action clear, Action startThread, Action<bool> paused, Action<bool> renderMode, Action pushMarker) + { + changeRenderModeMethod = renderMode; + pausedMethod = paused; + clearMethod = clear; + startThreadMethod = startThread; + pushMarkerMethod = pushMarker; + } + + public abstract void Clear(); + + public virtual void ChangeRenderMode(bool enabled) + { + changeRenderModeMethod(enabled); + } + + internal abstract void ClearPoints(); + + public void PushMarkerLine() + { + if (pushMarkerMethod != null) + { + pushMarkerMethod(); + } + } + } +} |
