A library of the 9-Axis Sensor BNO055 from Bosch Sensortec.
Requires the I2C-Master library - Link
Diff: bno055.cpp
- Revision:
- 1:6c64ebf1f2b5
- Parent:
- 0:a2a71c38065e
- Child:
- 2:d7baee646b4e
diff -r a2a71c38065e -r 6c64ebf1f2b5 bno055.cpp --- a/bno055.cpp Thu Jul 11 09:34:29 2019 +0000 +++ b/bno055.cpp Thu Jul 11 10:57:31 2019 +0000 @@ -20,8 +20,19 @@ */ #ifdef DEBUGGING_ENABLED -BNO055::BNO055(uint8_t slave_address, DoWi& dowi, DigitalOut& ResetPin, bool external_clk, Serial& DEBUG_SERIAL) : - m_i2c_master(dowi), +/** + * @brief Construct a new BNO055::BNO055 object + * + * This is the Debugging-version of the BNO055 class. The constructor requires an additional Serial-Object. + * + * @param slave_address The slave-address (determined by the Address-Pin on the chip) + * @param i2c_master I2C-Master object + * @param ResetPin Reference of the Output-Pin, which is connected to the Reset-Pin of the Sensor + * @param external_clk Boolean to determine if the Sensor uses an external 32kHz oscillator + * @param DEBUG_SERIAL Reference of the Serial-object used to debug the different functions. + */ +BNO055::BNO055(uint8_t slave_address, I2C_Master& i2c_master, DigitalOut& ResetPin, bool external_clk, Serial& DEBUG_SERIAL) : + m_i2c_master(i2c_master), m_ResetPin(ResetPin), m_DEBUG_SERIAL(DEBUG_SERIAL), m_bno055_address(slave_address << 1) @@ -47,6 +58,14 @@ setOrientation(REMAP_OPTION_P1); } #else +/** + * @brief Construct a new BNO055::BNO055 object + * + * @param slave_address The slave-address (determined by the Address-Pin on the chip) + * @param i2c_master I2C-Master object + * @param ResetPin Reference of the Output-Pin, which is connected to the Reset-Pin of the Sensor + * @param external_clk Boolean to determine if the Sensor uses an external 32kHz oscillator + */ BNO055::BNO055(uint8_t slave_address, I2C_Master& i2c_master, DigitalOut& ResetPin, bool external_clk) : m_i2c_master(i2c_master), m_ResetPin(ResetPin), @@ -74,6 +93,26 @@ } #endif +/** + * @brief Defines the format of the measurment units + * + * Following is a table, which displays all the possible formats for each measurement units. The column <i>Code<\i> + * contain the values, which are used in the programm. + * + * | Type | Formats | Code | + * | :----------- | :----------------------------------------------------- | :----------------------------- | + * | Orientation | Windows, Android - this changes the ranges of the axis.| WINDOWS, ANDROID | + * | Temperature | Celsius, Fahrenheit | CELSIUS, FAHRENHEIT | + * | Euler | Degree, Radians | DEGREE, RADIANS | + * | Gyroscope | degree per seconds, radian per seconds | DEGREE_PER_SEC, RADIAN_PER_SEC | + * | Acceleration | acceleration (m/s2), milli g-force | ACCELERATION, MILLI_G_FORCE | + * + * @param new_orientation_format + * @param new_temperature_format + * @param new_euler_format + * @param new_gyroscope_format + * @param new_acceleration_format + */ void BNO055::setUnitFormat(bno055_orientation_t new_orientation_format, bno055_temperature_t new_temperature_format, bno055_euler_t new_euler_format,