// Called by push devices (e.g. ANT+) void RealtimeWindow::updateData(RealtimeData &rtData) { displayPower = rtData.getWatts(); displayCadence = rtData.getCadence(); displayHeartRate = rtData.getHr(); displaySpeed = rtData.getSpeed(); displayLoad = rtData.getLoad(); // Gradient not supported return; }
void RealtimeWindow::guiUpdate() // refreshes the telemetry { RealtimeData rtData; // get latest telemetry from device (if it is a pull device e.g. Computrainer // if (status&RT_RUNNING && deviceController->doesPull() == true) { deviceController->getRealtimeData(rtData); displayPower = rtData.getWatts(); displayCadence = rtData.getCadence(); displayHeartRate = rtData.getHr(); displaySpeed = rtData.getSpeed(); displayLoad = rtData.getLoad(); } // Distance assumes current speed for the last second. from km/h to km/sec displayDistance += displaySpeed / (5 * 3600); // XXX assumes 200ms refreshrate displayWorkoutDistance += displaySpeed / (5 * 3600); // XXX assumes 200ms refreshrate total_msecs = session_elapsed_msec + session_time.elapsed(); lap_msecs = lap_elapsed_msec + lap_time.elapsed(); // update those LCDs! timeLCD->display(QString("%1:%2:%3.%4").arg(total_msecs/3600000) .arg((total_msecs%3600000)/60000,2,10,QLatin1Char('0')) .arg((total_msecs%60000)/1000,2,10,QLatin1Char('0')) .arg((total_msecs%1000)/100)); laptimeLCD->display(QString("%1:%2:%3.%4").arg(lap_msecs/3600000,2) .arg((lap_msecs%3600000)/60000,2,10,QLatin1Char('0')) .arg((lap_msecs%60000)/1000,2,10,QLatin1Char('0')) .arg((lap_msecs%1000)/100)); // Cadence, HR and Power needs to be rounded to 0 decimal places powerLCD->display(round(displayPower)); double val = round(displaySpeed * (useMetricUnits ? 1.0 : MILES_PER_KM) * 10.00)/10.00; speedLCD->display(QString::number(val, 'f', 1)); // always show 1 decimal point cadenceLCD->display(round(displayCadence)); heartrateLCD->display(round(displayHeartRate)); lapLCD->display(displayWorkoutLap+displayLap); // load or gradient depending on mode we are running if (status&RT_MODE_ERGO) loadLCD->display(displayLoad); else { val = round(displayGradient*10)/10.00; loadLCD->display(QString::number(val, 'f', 1)); // always show 1 decimal point } // distance val = round(displayDistance*(useMetricUnits ? 1.0 : MILES_PER_KM) *10.00) /10.00; distanceLCD->display(QString::number(val, 'f', 1)); // always show 1 decimal point // NZ Averages..... if (displayPower) { //NZAP is bogus - make it configurable!!! pwrcount++; if (pwrcount ==1) avgPower = displayPower; avgPower = ((avgPower * (double)pwrcount) + displayPower) /(double) (pwrcount+1); } if (displayCadence) { cadcount++; if (cadcount ==1) avgCadence = displayCadence; avgCadence = ((avgCadence * (double)cadcount) + displayCadence) /(double) (cadcount+1); } if (displayHeartRate) { hrcount++; if (hrcount ==1) avgHeartRate = displayHeartRate; avgHeartRate = ((avgHeartRate * (double)hrcount) + displayHeartRate) /(double) (hrcount+1); } if (displaySpeed) { spdcount++; if (spdcount ==1) avgSpeed = displaySpeed; avgSpeed = ((avgSpeed * (double)spdcount) + displaySpeed) /(double) (spdcount+1); } if (displayLoad && status&RT_MODE_ERGO) { lodcount++; if (lodcount ==1) avgLoad = displayLoad; avgLoad = ((avgLoad * (double)lodcount) + displayLoad) /(double) (lodcount+1); avgloadLCD->display((int)avgLoad); } if (status&RT_MODE_SPIN) { grdcount++; if (grdcount ==1) avgGradient = displayGradient; avgGradient = ((avgGradient * (double)grdcount) + displayGradient) /(double) (grdcount+1); avgloadLCD->display((int)avgGradient); } avgpowerLCD->display((int)avgPower); val = round(avgSpeed * (useMetricUnits ? 1.0 : MILES_PER_KM) * 10.00)/10.00; avgspeedLCD->display(QString::number(val, 'f', 1)); // always show 1 decimal point avgcadenceLCD->display((int)avgCadence); avgheartrateLCD->display((int)avgHeartRate); // now that plot.... rtPlot->pwrData.addData(displayPower); // add new data point rtPlot->cadData.addData(displayCadence); // add new data point rtPlot->spdData.addData(displaySpeed); // add new data point rtPlot->hrData.addData(displayHeartRate); // add new data point //rtPlot->lodData.addData(displayLoad); // add new Load point rtPlot->replot(); // redraw this->update(); }