Files
SpotMicroESP32-Leika/esp32/include/peripherals/magnetometer.h
T
2025-11-27 20:59:11 +01:00

73 lines
1.9 KiB
C++

#pragma once
#include <list>
#include <SPI.h>
#include <Wire.h>
#include <ArduinoJson.h>
#include <utils/math_utils.h>
#include <Adafruit_HMC5883_U.h>
#include <Adafruit_Sensor.h>
#include <peripherals/sensor.hpp>
struct MagnetometerMsg : public SensorMessageBase {
float rpy[3] {0, 0, 0};
float heading {-1};
void toJson(JsonVariant v) const override {
JsonArray arr = v.to<JsonArray>();
arr.add(rpy[0]);
arr.add(rpy[1]);
arr.add(rpy[2]);
arr.add(heading);
arr.add(success);
}
void fromJson(JsonVariantConst v) override {
JsonArrayConst arr = v.as<JsonArrayConst>();
rpy[0] = arr[0] | 0.0f;
rpy[1] = arr[1] | 0.0f;
rpy[2] = arr[2] | 0.0f;
heading = arr[3] | -1.0f;
success = arr[4] | false;
}
friend void toJson(JsonVariant v, MagnetometerMsg const& a) { a.toJson(v); }
};
class Magnetometer : public SensorBase<MagnetometerMsg> {
public:
bool initialize() override {
_msg.success = _mag.begin();
return _msg.success;
}
bool update() override {
if (!_msg.success) return false;
sensors_event_t event;
bool updated = _mag.getEvent(&event);
if (!updated) return false;
_msg.rpy[0] = event.magnetic.x;
_msg.rpy[1] = event.magnetic.y;
_msg.rpy[2] = event.magnetic.z;
_msg.heading = atan2(event.magnetic.y, event.magnetic.x);
_msg.heading += declinationAngle;
if (_msg.heading < 0) _msg.heading += 2 * PI;
if (_msg.heading > 2 * PI) _msg.heading -= 2 * PI;
_msg.heading *= 180 / M_PI;
return true;
}
float getMagX() { return _msg.rpy[0]; }
float getMagY() { return _msg.rpy[1]; }
float getMagZ() { return _msg.rpy[2]; }
float getHeading() { return _msg.heading; }
private:
Adafruit_HMC5883_Unified _mag {12345};
const float declinationAngle = 0.22;
};