PatientModel.cs 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. using System;
  2. using System.Collections.Generic;
  3. using System.ComponentModel;
  4. using System.Linq;
  5. using System.Text;
  6. using System.Threading;
  7. using System.Threading.Tasks;
  8. using System.Windows.Forms.DataVisualization.Charting;
  9. namespace FietsClientV2
  10. {
  11. class PatientModel
  12. {
  13. private static PatientModel _patientModel;
  14. public PatientForm patientform { private get; set; }
  15. public static PatientModel patientModel { get { return _patientModel ?? (_patientModel = new PatientModel()); } }
  16. private DataHandler dataHandler;
  17. private Thread workerThread;
  18. private String powerLog;
  19. private PatientModel()
  20. {
  21. dataHandler = new DataHandler();
  22. DataHandler.IncomingDataEvent += HandleBikeData; //initialize event
  23. }
  24. public void startComPort(string portname)
  25. {
  26. dataHandler.initComm(portname);
  27. }
  28. public void startAskingData()
  29. {
  30. workerThread = new Thread(() => workerThreadLoop());
  31. workerThread.Start();
  32. }
  33. private void workerThreadLoop()
  34. {
  35. while (true)
  36. {
  37. Thread.Sleep(1000);
  38. if( (patientform.actualBox.Text != powerLog) && (powerLog != null) && (Int32.Parse(powerLog) >= 0) )
  39. {
  40. setPower(powerLog);
  41. }
  42. try
  43. {
  44. dataHandler.sendData(DataHandler.STATUS);
  45. }
  46. catch (Exception e)
  47. {
  48. dataHandler.closeComm();
  49. }
  50. }
  51. }
  52. //event handler
  53. private List<DataPoint> speedPoints = new List<DataPoint>();
  54. private List<DataPoint> bpmPoints = new List<DataPoint>();
  55. private List<DataPoint> rpmPoints = new List<DataPoint>();
  56. private void HandleBikeData(string[] data)
  57. {
  58. if (patientform.InvokeRequired)
  59. {
  60. patientform.Invoke((new Action(() => HandleBikeData(data))));
  61. }
  62. else
  63. {
  64. //fill fields
  65. patientform.pulseBox.Text = data[0];
  66. patientform.rpmInfoBox.Text = data[1];
  67. patientform.speedInfoBox.Text = data[2];
  68. patientform.distanceInfoBox.Text = data[3];
  69. patientform.requestedBox.Text = data[4];
  70. patientform.energyInfoBox.Text = data[5];
  71. patientform.timeBox.Text = data[6];
  72. patientform.actualBox.Text = data[7];
  73. //fill graph speed
  74. speedPoints.Add(new DataPoint(Convert.ToDateTime(data[6]).ToOADate(), Convert.ToDouble(data[2])));
  75. patientform.speedChart.Series[0].Points.Clear();
  76. for (int i = 0; i < speedPoints.Count; i++)
  77. patientform.speedChart.Series[0].Points.Add(speedPoints[i]);
  78. if (speedPoints.Count > 25)
  79. speedPoints.RemoveAt(0);
  80. patientform.speedChart.Update();
  81. //fill graph pulse
  82. bpmPoints.Add(new DataPoint(Convert.ToDateTime(data[6]).ToOADate(), Convert.ToDouble(data[0])));
  83. patientform.bpmChart.Series[0].Points.Clear();
  84. for (int i = 0; i < bpmPoints.Count; i++)
  85. patientform.bpmChart.Series[0].Points.Add(bpmPoints[i]);
  86. if (bpmPoints.Count > 25)
  87. bpmPoints.RemoveAt(0);
  88. patientform.speedChart.Update();
  89. //fill graph rpm
  90. rpmPoints.Add(new DataPoint(Convert.ToDateTime(data[6]).ToOADate(), Convert.ToDouble(data[1])));
  91. patientform.rpmChart.Series[0].Points.Clear();
  92. for (int i = 0; i < rpmPoints.Count; i++)
  93. patientform.rpmChart.Series[0].Points.Add(rpmPoints[i]);
  94. if (rpmPoints.Count > 25)
  95. rpmPoints.RemoveAt(0);
  96. patientform.rpmChart.Update();
  97. }
  98. }
  99. public void closeComPort()
  100. {
  101. if (workerThread != null)
  102. workerThread.Interrupt();
  103. dataHandler.closeComm();
  104. }
  105. //change bike values
  106. public void setTimeMode(string time)
  107. {
  108. if (!dataHandler.checkBikeState(false)) return;
  109. dataHandler.sendData("CM");
  110. dataHandler.sendData("PT " + time);
  111. }
  112. public void setPower(string power)
  113. {
  114. powerLog = power;
  115. if (!dataHandler.checkBikeState(false)) return;
  116. dataHandler.sendData("CM");
  117. dataHandler.sendData("PW " + power);
  118. }
  119. public void setDistanceMode(string distance)
  120. {
  121. if (!dataHandler.checkBikeState(false)) return;
  122. dataHandler.sendData("CM");
  123. dataHandler.sendData("PD " + distance);
  124. }
  125. public void reset()
  126. {
  127. if (!dataHandler.checkBikeState(false)) return;
  128. dataHandler.sendData("RS");
  129. }
  130. }
  131. }