aboutsummaryrefslogtreecommitdiffstats
path: root/src/components/heartrate
diff options
context:
space:
mode:
Diffstat (limited to 'src/components/heartrate')
-rw-r--r--src/components/heartrate/HeartRateController.cpp8
-rw-r--r--src/components/heartrate/HeartRateController.h6
-rw-r--r--src/components/heartrate/Ppg.cpp5
-rw-r--r--src/components/heartrate/Ppg.h1
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);