DoctorModel.cs 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  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. foreach (string str in doctorSessions.Keys)
  51. {
  52. if (!(onlinePatients.Any(s => str.Contains(s))))
  53. {
  54. doctorform.RemoveSessionFromTabcontrol(str);
  55. doctorform.Invoke(new Action(() => doctorSessions.Remove(str)));
  56. }
  57. //onlinePatients.Find(username => username.Equals(str));
  58. }
  59. //voeg een onlinePatient toe aan een doctorSession
  60. foreach (string onlinePatient in onlinePatients)
  61. {
  62. if (!(doctorSessions.Keys.Any(s => onlinePatient.Contains(s))))
  63. doctorform.Invoke(new Action(() => doctorform.AddSessionToTabcontrol(onlinePatient)));
  64. }
  65. }
  66. }
  67. //display values
  68. private List<DataPoint> speedPoints = new List<DataPoint>();
  69. private List<DataPoint> bpmPoints = new List<DataPoint>();
  70. private List<DataPoint> rpmPoints = new List<DataPoint>();
  71. private void HandleBikeData(Measurement data)
  72. {
  73. if (doctorform.InvokeRequired)
  74. {
  75. doctorform.Invoke((new Action(() => HandleBikeData(data))));
  76. }
  77. else
  78. {
  79. //fill fields
  80. doctorform.summaryUserControl.pulseBox.Text = data.pulse.ToString();
  81. doctorform.summaryUserControl.rpmInfoBox.Text = data.rpm.ToString();
  82. doctorform.summaryUserControl.speedInfoBox.Text = data.speed.ToString();
  83. doctorform.summaryUserControl.distanceInfoBox.Text = data.distance.ToString();
  84. doctorform.summaryUserControl.requestedBox.Text = data.requestedPower.ToString();
  85. doctorform.summaryUserControl.energyInfoBox.Text = data.energy.ToString();
  86. doctorform.summaryUserControl.timeBox.Text = data.time.ToString() ;
  87. doctorform.summaryUserControl.actualBox.Text = data.actualPower.ToString();
  88. //fill graph speed
  89. speedPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.speed.ToString())));
  90. doctorform.summaryUserControl.speedChart.Series[0].Points.Clear();
  91. for (int i = 0; i < speedPoints.Count; i++)
  92. doctorform.summaryUserControl.speedChart.Series[0].Points.Add(speedPoints[i]);
  93. if (speedPoints.Count > 25)
  94. speedPoints.RemoveAt(0);
  95. doctorform.summaryUserControl.speedChart.Update();
  96. //fill graph pulse
  97. bpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.pulse.ToString())));
  98. doctorform.summaryUserControl.bpmChart.Series[0].Points.Clear();
  99. for (int i = 0; i < bpmPoints.Count; i++)
  100. doctorform.summaryUserControl.bpmChart.Series[0].Points.Add(bpmPoints[i]);
  101. if (bpmPoints.Count > 25)
  102. bpmPoints.RemoveAt(0);
  103. doctorform.summaryUserControl.speedChart.Update();
  104. //fill graph rpm
  105. rpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.rpm.ToString())));
  106. doctorform.summaryUserControl.rpmChart.Series[0].Points.Clear();
  107. for (int i = 0; i < rpmPoints.Count; i++)
  108. doctorform.summaryUserControl.rpmChart.Series[0].Points.Add(rpmPoints[i]);
  109. if (rpmPoints.Count > 25)
  110. rpmPoints.RemoveAt(0);
  111. doctorform.summaryUserControl.rpmChart.Update();
  112. }
  113. }
  114. }
  115. }