DoctorModel.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  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 FietsClient
  10. {
  11. class DoctorModel
  12. {
  13. private static DoctorModel _doctorModel;
  14. public DoctorForm doctorform { get; set; }
  15. public static DoctorModel doctorModel { get { return _doctorModel ?? (_doctorModel = new DoctorModel()); } }
  16. public TcpConnection tcpConnection { get; set; }
  17. private Thread receiveDataThread;
  18. public List<string> onlinePatients { get; set; } = new List<string>();
  19. public Dictionary<string, Forms.DoctorSessionUC> doctorSessions { get; set; } = new Dictionary<string, Forms.DoctorSessionUC>();
  20. private DoctorModel()
  21. {
  22. startAskingData();
  23. }
  24. public void startAskingData()
  25. {
  26. receiveDataThread = new Thread(() => receiveDataThreadLoop());
  27. receiveDataThread.Start();
  28. }
  29. public void stopAskingData()
  30. {
  31. receiveDataThread.Abort();
  32. }
  33. private void receiveDataThreadLoop()
  34. {
  35. while (true)
  36. {
  37. Thread.Sleep(1000);
  38. //receive data and display in through handle bike data
  39. //HandleBikeData(tcpConnection.currentData.GetSessions().Last().GetLastMeasurement());
  40. CheckOnlineUsersUpdated(); //misschien alleen als er wat binnenkomt? ff over nadenken nog
  41. }
  42. }
  43. public void CheckOnlineUsersUpdated()
  44. {
  45. tcpConnection.SendGetActivePatients();
  46. if (onlinePatients.Count != doctorSessions.Count || true)
  47. {
  48. // ruim eerst alle doctorSessions op die niet van toepassing zijn
  49. foreach (string str in doctorSessions.Keys)
  50. {
  51. if (!(onlinePatients.Any(s => str.Contains(s))))
  52. {
  53. doctorform.RemoveSessionFromTabcontrol(str);
  54. doctorform.Invoke(new Action(() => doctorSessions.Remove(str)));
  55. }
  56. //onlinePatients.Find(username => username.Equals(str));
  57. }
  58. //voeg een onlinePatient toe aan een doctorSession
  59. foreach (string onlinePatient in onlinePatients)
  60. {
  61. if (!(doctorSessions.Keys.Any(s => onlinePatient.Contains(s))))
  62. doctorform.Invoke(new Action(() => doctorform.AddSessionToTabcontrol(onlinePatient)));
  63. }
  64. }
  65. }
  66. //display values
  67. private List<DataPoint> speedPoints = new List<DataPoint>();
  68. private List<DataPoint> bpmPoints = new List<DataPoint>();
  69. private List<DataPoint> rpmPoints = new List<DataPoint>();
  70. private void HandleBikeData(Measurement data)
  71. {
  72. if (doctorform.InvokeRequired)
  73. {
  74. doctorform.Invoke((new Action(() => HandleBikeData(data))));
  75. }
  76. else
  77. {
  78. //fill fields
  79. doctorform.summaryUserControl.pulseBox.Text = data.pulse.ToString();
  80. doctorform.summaryUserControl.rpmInfoBox.Text = data.rpm.ToString();
  81. doctorform.summaryUserControl.speedInfoBox.Text = data.speed.ToString();
  82. doctorform.summaryUserControl.distanceInfoBox.Text = data.distance.ToString();
  83. doctorform.summaryUserControl.requestedBox.Text = data.requestedPower.ToString();
  84. doctorform.summaryUserControl.energyInfoBox.Text = data.energy.ToString();
  85. doctorform.summaryUserControl.timeBox.Text = data.time.ToString() ;
  86. doctorform.summaryUserControl.actualBox.Text = data.actualPower.ToString();
  87. //fill graph speed
  88. speedPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.speed.ToString())));
  89. doctorform.summaryUserControl.speedChart.Series[0].Points.Clear();
  90. for (int i = 0; i < speedPoints.Count; i++)
  91. doctorform.summaryUserControl.speedChart.Series[0].Points.Add(speedPoints[i]);
  92. if (speedPoints.Count > 25)
  93. speedPoints.RemoveAt(0);
  94. doctorform.summaryUserControl.speedChart.Update();
  95. //fill graph pulse
  96. bpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.pulse.ToString())));
  97. doctorform.summaryUserControl.bpmChart.Series[0].Points.Clear();
  98. for (int i = 0; i < bpmPoints.Count; i++)
  99. doctorform.summaryUserControl.bpmChart.Series[0].Points.Add(bpmPoints[i]);
  100. if (bpmPoints.Count > 25)
  101. bpmPoints.RemoveAt(0);
  102. doctorform.summaryUserControl.speedChart.Update();
  103. //fill graph rpm
  104. rpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.rpm.ToString())));
  105. doctorform.summaryUserControl.rpmChart.Series[0].Points.Clear();
  106. for (int i = 0; i < rpmPoints.Count; i++)
  107. doctorform.summaryUserControl.rpmChart.Series[0].Points.Add(rpmPoints[i]);
  108. if (rpmPoints.Count > 25)
  109. rpmPoints.RemoveAt(0);
  110. doctorform.summaryUserControl.rpmChart.Update();
  111. }
  112. }
  113. }
  114. }