| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- using System;
- using System.Collections.Generic;
- using System.ComponentModel;
- using System.Drawing;
- using System.Data;
- using System.Linq;
- using System.Text;
- using System.Threading.Tasks;
- using System.Windows.Forms;
- using System.Windows.Forms.DataVisualization.Charting;
- using FietsLibrary.JSONObjecten;
- namespace FietsClient.Forms
- {
- public partial class DoctorSessionUC : UserControl
- {
- public string patientID { get; private set; }
- public DoctorSessionUC(string patientID)
- {
- InitializeComponent();
- this.patientID = patientID;
- nameBox.Text = patientID;
- }
- private void setDistanceButton_Click(object sender, EventArgs e)
- {
- int distance;
- Int32.TryParse(setDistanceBox.Text, out distance);
- DoctorModel.doctorModel.tcpConnection.SendDistance(distance, patientID);
- }
- private void setTimeButton_Click(object sender, EventArgs e)
- {
- int minutes, seconds;
- Int32.TryParse(setTimeMinutesBox.Text, out minutes);
- Int32.TryParse(setTimeSecondsBox.Text, out seconds);
- DoctorModel.doctorModel.tcpConnection.SendTime(minutes, seconds, patientID);
- }
- private void setPowerButton_Click(object sender, EventArgs e)
- {
- int power;
- Int32.TryParse(setPowerBox.Text, out power);
- DoctorModel.doctorModel.tcpConnection.SendPower(power, patientID);
- }
- private void button1_Click(object sender, EventArgs e)
- {
- DoctorModel.doctorModel.tcpConnection.SendStartStopSession(true, patientID);
- }
- private void button2_Click(object sender, EventArgs e)
- {
- DoctorModel.doctorModel.tcpConnection.SendStartStopSession(false, patientID);
- }
- public void ClearOldSession()
- {
- if (InvokeRequired)
- Invoke(new Action(() => ClearOldSession()));
- else
- {
- speedPoints.Clear();
- bpmPoints.Clear();
- rpmPoints.Clear();
- pulseBox.Clear();
- rpmInfoBox.Clear();
- speedInfoBox.Clear();
- distanceInfoBox.Clear();
- requestedBox.Clear();
- energyInfoBox.Clear();
- timeBox.Clear();
- actualBox.Clear();
- }
-
- }
- private List<DataPoint> speedPoints = new List<DataPoint>();
- private List<DataPoint> bpmPoints = new List<DataPoint>();
- private List<DataPoint> rpmPoints = new List<DataPoint>();
- public void HandleSessionBikeData(Measurement data)
- {
- if (InvokeRequired)
- {
- Invoke((new Action(() => HandleSessionBikeData(data))));
- }
- else
- {
- int actualMinutes = (int)(data.time / 60.0);
- string actualTime = actualMinutes + ":" + (data.time - actualMinutes * 60).ToString();
- //fill fields
- pulseBox.Text = data.pulse.ToString();
- rpmInfoBox.Text = data.rpm.ToString();
- speedInfoBox.Text = data.speed.ToString();
- distanceInfoBox.Text = data.distance.ToString();
- requestedBox.Text = data.requestedPower.ToString();
- energyInfoBox.Text = data.energy.ToString();
- timeBox.Text = data.time.ToString();
- actualBox.Text = data.actualPower.ToString();
- //fill graph speed
- speedPoints.Add(new DataPoint(Convert.ToDateTime(actualTime).ToOADate(), Convert.ToDouble(data.speed)));
- speedChart.Series[0].Points.Clear();
- for (int i = 0; i < speedPoints.Count; i++)
- speedChart.Series[0].Points.Add(speedPoints[i]);
- if (speedPoints.Count > 25)
- speedPoints.RemoveAt(0);
- speedChart.Update();
- //fill graph pulse
- bpmPoints.Add(new DataPoint(Convert.ToDateTime(actualTime).ToOADate(), Convert.ToDouble(data.pulse)));
- bpmChart.Series[0].Points.Clear();
- for (int i = 0; i < bpmPoints.Count; i++)
- bpmChart.Series[0].Points.Add(bpmPoints[i]);
- if (bpmPoints.Count > 25)
- bpmPoints.RemoveAt(0);
- speedChart.Update();
- //fill graph rpm
- rpmPoints.Add(new DataPoint(Convert.ToDateTime(actualTime).ToOADate(), Convert.ToDouble(data.rpm)));
- rpmChart.Series[0].Points.Clear();
- for (int i = 0; i < rpmPoints.Count; i++)
- rpmChart.Series[0].Points.Add(rpmPoints[i]);
- if (rpmPoints.Count > 25)
- rpmPoints.RemoveAt(0);
- rpmChart.Update();
- }
- }
- }
- }
|