VATPerformanceViewModel.cs 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. using LiveCharts;
  2. using MECF.Framework.Common.DataCenter;
  3. using MECF.Framework.Common.OperationCenter;
  4. using Microsoft.Win32;
  5. using Prism.Commands;
  6. using Prism.Mvvm;
  7. using System;
  8. using System.IO;
  9. using System.Linq;
  10. using System.Windows.Threading;
  11. using Venus_MainPages.Unity;
  12. using Venus_Unity;
  13. namespace Venus_MainPages.ViewModels
  14. {
  15. internal class VATPerformanceViewModel : BindableBase
  16. {
  17. #region 私有字段
  18. private int m_GasFlow;
  19. private int m_GasTime;
  20. private int m_GasSelectedIndex;
  21. private string m_ModuleName = "PMA";
  22. ChartValues<double> m_CurrentLineSeries = new ChartValues<double>();
  23. ChartValues<double> m_ReferenceLineSeries = new ChartValues<double>();
  24. DispatcherTimer timer = new DispatcherTimer();
  25. VATPerformanceResult m_VATPerformanceResult;
  26. #endregion
  27. #region 属性
  28. public string ModuleName
  29. {
  30. get { return m_ModuleName; }
  31. set { SetProperty(ref m_ModuleName, value); }
  32. }
  33. public int GasFlow
  34. {
  35. get { return m_GasFlow; }
  36. set { SetProperty(ref m_GasFlow, value); }
  37. }
  38. public int GasTime
  39. {
  40. get { return m_GasTime; }
  41. set { SetProperty(ref m_GasTime, value); }
  42. }
  43. public int GasSelectedIndex
  44. {
  45. get { return m_GasSelectedIndex; }
  46. set { SetProperty(ref m_GasSelectedIndex, value); }
  47. }
  48. public ChartValues<double> CurrentLineSeries
  49. {
  50. get { return m_CurrentLineSeries; }
  51. set { SetProperty(ref m_CurrentLineSeries, value); }
  52. }
  53. public ChartValues<double> ReferenceLineSeries
  54. {
  55. get { return m_ReferenceLineSeries; }
  56. set { SetProperty(ref m_ReferenceLineSeries, value); }
  57. }
  58. #endregion
  59. #region 命令
  60. private DelegateCommand _SelectGasCommand;
  61. public DelegateCommand SelectGasCommand =>
  62. _SelectGasCommand ?? (_SelectGasCommand = new DelegateCommand(OnSelectGas));
  63. private DelegateCommand _StartCommand;
  64. public DelegateCommand StartCommand =>
  65. _StartCommand ?? (_StartCommand = new DelegateCommand(OnStart));
  66. private DelegateCommand _LoadReferenceCommand;
  67. public DelegateCommand LoadReferenceCommand =>
  68. _LoadReferenceCommand ?? (_LoadReferenceCommand = new DelegateCommand(OnLoadReference));
  69. private DelegateCommand _AbortCommand;
  70. public DelegateCommand AbortCommand =>
  71. _AbortCommand ?? (_AbortCommand = new DelegateCommand(OnAbort));
  72. private DelegateCommand _SaveCommand;
  73. public DelegateCommand SaveCommand =>
  74. _SaveCommand ?? (_SaveCommand = new DelegateCommand(OnSave));
  75. #endregion
  76. #region 构造函数
  77. public VATPerformanceViewModel()
  78. {
  79. OnSelectGas();
  80. GasTime = 60;
  81. timer.Interval = TimeSpan.FromSeconds(2);
  82. timer.Tick += Timer_Tick;
  83. }
  84. #endregion
  85. #region 命令方法
  86. private void OnSelectGas()
  87. {
  88. var value=Convert.ToInt32( QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.MfcGas{(GasSelectedIndex+1).ToString()}.MfcN2Scale"));
  89. var xishu= Convert.ToDouble(QueryDataClient.Instance.Service.GetConfig($"{ModuleName}.MfcGas{(GasSelectedIndex + 1).ToString()}.MfcScaleFactor"));
  90. GasFlow = (int)(value * xishu) / 2;
  91. }
  92. //public enum CMPressure
  93. //{
  94. // CM1,
  95. // CM2,
  96. //}
  97. //private CMPressure currentCMPressure = CMPressure.CM1;
  98. private void OnStart()
  99. {
  100. //currentCMPressure = CMPressure.CM1;
  101. m_VATPerformanceResult = new VATPerformanceResult();
  102. m_VATPerformanceResult.StartTime = DateTime.Now.ToString();
  103. m_VATPerformanceResult.FlowTime = GasTime;
  104. m_VATPerformanceResult.GasName = $"Gas{GasSelectedIndex+1}";
  105. CurrentLineSeries = new ChartValues<double>();
  106. timer.Start();
  107. InvokeClient.Instance.Service.DoOperation($"{ModuleName}.VATPerformanceTest", GasSelectedIndex+1, 1000 * GasTime, GasFlow);
  108. }
  109. private void OnLoadReference()
  110. {
  111. //ReferenceLineSeries.Clear();
  112. //for (int i = 0; i < 21; i++)
  113. //{
  114. // double value = Math.Round((double)GasFlow / (double)((i + 2) * 50),3);
  115. // ReferenceLineSeries.Add(value);
  116. //}
  117. OpenFileDialog dialog = new OpenFileDialog();
  118. dialog.Filter = ".json|*.json";
  119. dialog.InitialDirectory = Path.Combine(QueryDataClient.Instance.Service.GetData("GetRTPath").ToString(), "VATPerformanceResult");
  120. if (dialog.ShowDialog() == true)
  121. {
  122. string SelectedPath = dialog.FileName;
  123. var value = SerializeHelper.Instance.ReadFromJsonFile<VATPerformanceResult>(SelectedPath);
  124. ReferenceLineSeries.Clear();
  125. value.ValuePairs.ForEach(x =>
  126. {
  127. ReferenceLineSeries.Add(x);
  128. });
  129. }
  130. else
  131. {
  132. ReferenceLineSeries.Clear();
  133. ReferenceLineSeries.Add(0);
  134. }
  135. }
  136. private void OnAbort()
  137. {
  138. timer.Stop();
  139. InvokeClient.Instance.Service.DoOperation($"{ModuleName}.Abort");
  140. CurrentLineSeries = new ChartValues<double>();
  141. }
  142. private void OnSave()
  143. {
  144. SerializeHelper.Instance.WriteToJsonFile<VATPerformanceResult>(m_VATPerformanceResult, $"VATPerformanceResult/{m_VATPerformanceResult.GasName}/{DateTime.Now.ToString("yyyyMMddHHmm")}.json");
  145. }
  146. #endregion
  147. #region 私有方法
  148. private void Timer_Tick(object sender, EventArgs e)
  149. {
  150. CurrentLineSeries.Clear();
  151. var values = QueryDataClient.Instance.Service.GetData($"{ModuleName}.VATPerformanceResult").ToString();
  152. values.Split(',').ToList().ForEach(x =>
  153. {
  154. if (x != "")
  155. {
  156. CurrentLineSeries.Add(Math.Round( Convert.ToDouble(x),3));
  157. }
  158. });
  159. if (CurrentLineSeries.Count == 20)
  160. {
  161. timer.Stop();
  162. }
  163. }
  164. #endregion
  165. }
  166. }