esp32_BNO08x/source/report/BNO08xRptCalGyro.cpp

52 lines
1.4 KiB
C++
Raw Normal View History

/**
* @file BNO08xRptCalGyro.cpp
* @author Myles Parfeniuk
*/
2024-11-24 04:08:15 +00:00
#include "BNO08xRptCalGyro.hpp"
/**
* @brief Updates calibrated gyro data from decoded sensor event.
*
* @param sensor_val The sh2_SensorValue_t struct used in sh2_decodeSensorEvent() call.
*
* @return void, nothing to return
*/
void BNO08xRptCalGyro::update_data(sh2_SensorValue_t* sensor_val)
{
lock_user_data();
data = sensor_val->un.gyroscope;
2024-11-26 21:28:27 +00:00
data.accuracy = static_cast<BNO08xAccuracy>(sensor_val->status);
update_timestamp(sensor_val);
unlock_user_data();
2024-11-24 04:08:15 +00:00
2024-12-05 06:09:15 +00:00
if (rpt_bit & xEventGroupGetBits(sync_ctx->evt_grp_rpt_en))
2024-11-24 04:08:15 +00:00
signal_data_available();
}
/**
* @brief Enables calibrated gyro reports such that the BNO08x begins sending them.
*
* @param report_period_us The period/interval of the report in microseconds.
* @param sensor_cfg Sensor special configuration (optional, see
* BNO08xPrivateTypes::default_sensor_cfg for defaults).
*
* @return True if report was successfully enabled.
*/
2024-12-27 02:02:09 +00:00
bool BNO08xRptCalGyro::enable(uint32_t time_between_reports, sh2_SensorConfig_t sensor_cfg)
{
return BNO08xRpt::rpt_enable(time_between_reports, sensor_cfg);
}
/**
* @brief Grabs most recent gyroscope data (velocity), units are in rad/s.
*
* @return Struct containing requested data.
*/
bno08x_gyro_t BNO08xRptCalGyro::get()
{
lock_user_data();
bno08x_gyro_t rqdata = data;
unlock_user_data();
return rqdata;
}