esp32_BNO08x/source/report/BNO08xRptIGyroRV.cpp

50 lines
1.4 KiB
C++
Raw Normal View History

#include "BNO08xRptIGyroRV.hpp"
#include "BNO08x.hpp"
/**
* @brief Updates gyro integrated 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 BNO08xRptIGyroRV::update_data(sh2_SensorValue_t* sensor_val)
{
imu->lock_user_data();
data = sensor_val->un.gyroIntegratedRV;
2024-11-26 21:28:27 +00:00
data.accuracy = static_cast<BNO08xAccuracy>(sensor_val->status);
data_vel = sensor_val->un.gyroIntegratedRV;
imu->unlock_user_data();
2024-11-24 04:08:15 +00:00
if (rpt_bit & xEventGroupGetBits(imu->evt_grp_report_en))
signal_data_available();
}
/**
* @brief Grabs most recent gyro integrated rotation vector data.
*
* @param quat Struct to store requested unit quaternion data.
* @param vel Struct to store requested velocity data (units in rad/s).
*
* @return void, nothing to return
*/
void BNO08xRptIGyroRV::get(bno08x_quat_t& quat, bno08x_ang_vel_t& vel)
{
imu->lock_user_data();
quat = data;
vel = data_vel;
imu->unlock_user_data();
}
/**
* @brief Grabs most recent gyro integrated rotation vector angular velocity data, units are in rad/s.
*
* @return Struct containing requested data.
*/
bno08x_ang_vel_t BNO08xRptIGyroRV::get_vel()
{
imu->lock_user_data();
bno08x_ang_vel_t rqdata = data_vel;
imu->unlock_user_data();
return rqdata;
}