DoctorModel.cs 3.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  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 { private get; set; }
  17. private Thread receiveDataLoop;
  18. public DoctorModel()
  19. {
  20. }
  21. public void startAskingData()
  22. {
  23. receiveDataLoop = new Thread(() => receiveDataThreadLoop());
  24. receiveDataLoop.Start();
  25. }
  26. private void receiveDataThreadLoop()
  27. {
  28. while (true)
  29. {
  30. Thread.Sleep(1000);
  31. //receive data and display in through handle bike data
  32. HandleBikeData(tcpConnection.currentData.GetSessions().Last().GetLastMeasurement());
  33. }
  34. }
  35. //display values
  36. private List<DataPoint> speedPoints = new List<DataPoint>();
  37. private List<DataPoint> bpmPoints = new List<DataPoint>();
  38. private List<DataPoint> rpmPoints = new List<DataPoint>();
  39. private void HandleBikeData(Measurement data)
  40. {
  41. if (doctorform.InvokeRequired)
  42. {
  43. doctorform.Invoke((new Action(() => HandleBikeData(data))));
  44. }
  45. else
  46. {
  47. //fill fields
  48. doctorform.pulseBox.Text = data.pulse.ToString();
  49. doctorform.rpmInfoBox.Text = data.rpm.ToString();
  50. doctorform.speedInfoBox.Text = data.speed.ToString();
  51. doctorform.distanceInfoBox.Text = data.distance.ToString();
  52. doctorform.requestedBox.Text = data.requestedPower.ToString();
  53. doctorform.energyInfoBox.Text = data.energy.ToString();
  54. doctorform.timeBox.Text = data.time.ToString() ;
  55. doctorform.actualBox.Text = data.actualPower.ToString();
  56. //fill graph speed
  57. speedPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.speed.ToString())));
  58. doctorform.speedChart.Series[0].Points.Clear();
  59. for (int i = 0; i < speedPoints.Count; i++)
  60. doctorform.speedChart.Series[0].Points.Add(speedPoints[i]);
  61. if (speedPoints.Count > 25)
  62. speedPoints.RemoveAt(0);
  63. doctorform.speedChart.Update();
  64. //fill graph pulse
  65. bpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.pulse.ToString())));
  66. doctorform.bpmChart.Series[0].Points.Clear();
  67. for (int i = 0; i < bpmPoints.Count; i++)
  68. doctorform.bpmChart.Series[0].Points.Add(bpmPoints[i]);
  69. if (bpmPoints.Count > 25)
  70. bpmPoints.RemoveAt(0);
  71. doctorform.speedChart.Update();
  72. //fill graph rpm
  73. rpmPoints.Add(new DataPoint(Convert.ToDateTime(data.time.ToString()).ToOADate(), Convert.ToDouble(data.rpm.ToString())));
  74. doctorform.rpmChart.Series[0].Points.Clear();
  75. for (int i = 0; i < rpmPoints.Count; i++)
  76. doctorform.rpmChart.Series[0].Points.Add(rpmPoints[i]);
  77. if (rpmPoints.Count > 25)
  78. rpmPoints.RemoveAt(0);
  79. doctorform.rpmChart.Update();
  80. }
  81. }
  82. }
  83. }