diff options
| author | mark9064 <30447455+mark9064@users.noreply.github.com> | 2025-06-18 14:09:57 +0100 |
|---|---|---|
| committer | mark9064 <30447455+mark9064@users.noreply.github.com> | 2025-11-05 10:34:49 +0000 |
| commit | 8daddf87782c1228a44528da6f67d8dfce3edb40 (patch) | |
| tree | dead2a56c55f5eec74c70f42389c89e379aa4ce7 /src/components/heartrate | |
| parent | 04afd22943cf4d6a826e09cf5fd246886ee7cacf (diff) | |
Background heartrate measurement
Co-Authored-By: Patric Gruber <me@patric-gruber.at>
Diffstat (limited to 'src/components/heartrate')
| -rw-r--r-- | src/components/heartrate/HeartRateController.cpp | 8 | ||||
| -rw-r--r-- | src/components/heartrate/HeartRateController.h | 6 | ||||
| -rw-r--r-- | src/components/heartrate/Ppg.cpp | 5 | ||||
| -rw-r--r-- | src/components/heartrate/Ppg.h | 1 |
4 files changed, 13 insertions, 7 deletions
diff --git a/src/components/heartrate/HeartRateController.cpp b/src/components/heartrate/HeartRateController.cpp index e0d69272..c365e865 100644 --- a/src/components/heartrate/HeartRateController.cpp +++ b/src/components/heartrate/HeartRateController.cpp @@ -12,17 +12,17 @@ void HeartRateController::Update(HeartRateController::States newState, uint8_t h } } -void HeartRateController::Start() { +void HeartRateController::Enable() { if (task != nullptr) { state = States::NotEnoughData; - task->PushMessage(Pinetime::Applications::HeartRateTask::Messages::StartMeasurement); + task->PushMessage(Pinetime::Applications::HeartRateTask::Messages::Enable); } } -void HeartRateController::Stop() { +void HeartRateController::Disable() { if (task != nullptr) { state = States::Stopped; - task->PushMessage(Pinetime::Applications::HeartRateTask::Messages::StopMeasurement); + task->PushMessage(Pinetime::Applications::HeartRateTask::Messages::Disable); } } diff --git a/src/components/heartrate/HeartRateController.h b/src/components/heartrate/HeartRateController.h index f66c79f8..5bd3a8ef 100644 --- a/src/components/heartrate/HeartRateController.h +++ b/src/components/heartrate/HeartRateController.h @@ -15,11 +15,11 @@ namespace Pinetime { namespace Controllers { class HeartRateController { public: - enum class States { Stopped, NotEnoughData, NoTouch, Running }; + enum class States : uint8_t { Stopped, NotEnoughData, NoTouch, Running }; HeartRateController() = default; - void Start(); - void Stop(); + void Enable(); + void Disable(); void Update(States newState, uint8_t heartRate); void SetHeartRateTask(Applications::HeartRateTask* task); diff --git a/src/components/heartrate/Ppg.cpp b/src/components/heartrate/Ppg.cpp index efbed852..25be6237 100644 --- a/src/components/heartrate/Ppg.cpp +++ b/src/components/heartrate/Ppg.cpp @@ -155,8 +155,12 @@ int8_t Ppg::Preprocess(uint16_t hrs, uint16_t als) { int Ppg::HeartRate() { if (dataIndex < dataLength) { + if (!enoughData) { + return -2; + } return 0; } + enoughData = true; int hr = 0; hr = ProcessHeartRate(resetSpectralAvg); resetSpectralAvg = false; @@ -171,6 +175,7 @@ int Ppg::HeartRate() { void Ppg::Reset(bool resetDaqBuffer) { if (resetDaqBuffer) { dataIndex = 0; + enoughData = false; } avgIndex = 0; dataAverage.fill(0.0f); diff --git a/src/components/heartrate/Ppg.h b/src/components/heartrate/Ppg.h index 373e7985..78935382 100644 --- a/src/components/heartrate/Ppg.h +++ b/src/components/heartrate/Ppg.h @@ -71,6 +71,7 @@ namespace Pinetime { uint16_t dataIndex = 0; float peakLocation; bool resetSpectralAvg = true; + bool enoughData = false; int ProcessHeartRate(bool init); float HeartRateAverage(float hr); |
