esp32_BNO08x/source/report/BNO08xRptRVGeomag.cpp

69 lines
1.6 KiB
C++
Raw Normal View History

/**
* @file BNO08xRptRVGeomag.cpp
* @author Myles Parfeniuk
*/
#include "BNO08xRptRVGeomag.hpp"
/**
* @brief Updates geomagnetic rotation vector data from decoded sensor event.
*
* @param sensor_val The sh2_SensorValue_t struct used in sh2_decodeSensorEvent() call.
*
* @return void, nothing to return
*/
void BNO08xRptRVGeomag::update_data(sh2_SensorValue_t* sensor_val)
{
lock_user_data();
data = sensor_val->un.geoMagRotationVector;
2024-11-26 21:28:27 +00:00
data.accuracy = static_cast<BNO08xAccuracy>(sensor_val->status);
unlock_user_data();
2024-11-24 04:08:15 +00:00
if (rpt_bit & xEventGroupGetBits(*_evt_grp_rpt_en))
2024-11-24 04:08:15 +00:00
signal_data_available();
}
/**
* @brief Tares geomagnetic rotation vector.
*
* @param x If true tare x axis (optional, default true).
* @param y If true tare y axis (optional, default true).
* @param z If true tare z axis (optional, default true).
*
* @return True if tare operation succeeded.
*/
bool BNO08xRptRVGeomag::tare(bool x, bool y, bool z)
{
return BNO08xRptRVGeneric::tare(x, y, z, SH2_TARE_BASIS_GEOMAGNETIC_ROTATION_VECTOR);
}
/**
* @brief Saves most recent tare operation to BNO08x internal flash, such that it persists on reset.
*
* @return True if tare operation succeeded.
*/
bool BNO08xRptRVGeomag::tare_persist()
{
int success = SH2_ERR;
lock_sh2_HAL();
success = sh2_persistTare();
unlock_sh2_HAL();
if (success != SH2_OK)
return false;
else
return true;
}
/**
* @brief Clears most recent tare operation.
*
* @return void, nothing to return
*/
void BNO08xRptRVGeomag::tare_clear()
{
lock_sh2_HAL();
sh2_clearTare();
unlock_sh2_HAL();
}