VATPerformanceViewModel.cs 6.4 KB

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