DoctorModel.cs 5.7 KB

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