2021-10-17 02:23:44 -04:00
|
|
|
#pragma once
|
|
|
|
#define min // workaround: nimble's min/max macros conflict with libstdc++
|
|
|
|
#define max
|
|
|
|
#include <host/ble_gap.h>
|
|
|
|
#include <atomic>
|
|
|
|
#undef max
|
|
|
|
#undef min
|
|
|
|
|
|
|
|
namespace Pinetime {
|
|
|
|
namespace System {
|
|
|
|
class SystemTask;
|
|
|
|
}
|
2023-01-07 15:23:15 -05:00
|
|
|
|
2021-10-17 02:23:44 -04:00
|
|
|
namespace Controllers {
|
|
|
|
class MotionController;
|
2023-01-07 15:23:15 -05:00
|
|
|
|
2021-10-17 02:23:44 -04:00
|
|
|
class MotionService {
|
|
|
|
public:
|
|
|
|
MotionService(Pinetime::System::SystemTask& system, Controllers::MotionController& motionController);
|
|
|
|
void Init();
|
2022-12-30 16:31:31 -05:00
|
|
|
int OnStepCountRequested(uint16_t attributeHandle, ble_gatt_access_ctxt* context);
|
2021-10-26 14:31:18 -04:00
|
|
|
void OnNewStepCountValue(uint32_t stepCount);
|
2021-10-17 02:23:44 -04:00
|
|
|
void OnNewMotionValues(int16_t x, int16_t y, int16_t z);
|
|
|
|
|
2022-12-30 16:31:31 -05:00
|
|
|
void SubscribeNotification(uint16_t attributeHandle);
|
|
|
|
void UnsubscribeNotification(uint16_t attributeHandle);
|
2021-10-17 02:23:44 -04:00
|
|
|
|
|
|
|
private:
|
|
|
|
Pinetime::System::SystemTask& system;
|
|
|
|
Controllers::MotionController& motionController;
|
|
|
|
|
|
|
|
struct ble_gatt_chr_def characteristicDefinition[3];
|
|
|
|
struct ble_gatt_svc_def serviceDefinition[2];
|
|
|
|
|
|
|
|
uint16_t stepCountHandle;
|
|
|
|
uint16_t motionValuesHandle;
|
|
|
|
std::atomic_bool stepCountNoficationEnabled {false};
|
|
|
|
std::atomic_bool motionValuesNoficationEnabled {false};
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|