A storage struct data need to be declared. The data is then read by the sensor by the Environmental_readData() function and then stored in a passed reference of the storage struct.
The temperature, humidity and pressure measurements can also be read from the environmental sensor separately, if the only one or two of them are needed.
// Function that read and print the sensor data of the BME280 to the console of the XDK-Workbench
static void readEnvironmental(xTimerHandle xTimer)
{
(void) xTimer;
Retcode_T returnValue = RETCODE_FAILURE;
/* read and print BME280 environmental sensor data */
Environmental_Data_T bme280 = { INT32_C(0), UINT32_C(0), UINT32_C(0) };
returnValue = Environmental_readData(xdkEnvironmental_BME280_Handle, &bme280);
if ( RETCODE_OK == returnValue) {
printf("BME280 Environmental Data : p =%ld Pa T =%ld mDeg h =%ld %%rh\n\r",
(long int) bme280.pressure, (long int) bme280.temperature, (long int) bme280.humidity);
}
}
Then we declared the function to initialized the sensor and variable. We need to use the function of Environmental_init(xdkEnvironmental_BME280_Handle);
// Function that initializes the Environmental sensor with the BME280 handler and with additional presettings
static void initEnvironmental(void)
{
Retcode_T returnValue = RETCODE_FAILURE;
Retcode_T returnOverSamplingValue = RETCODE_FAILURE;
Retcode_T returnFilterValue = RETCODE_FAILURE;
/* initialize environmental sensor */
returnValue = Environmental_init(xdkEnvironmental_BME280_Handle);
if ( RETCODE_OK != returnValue) {
printf("BME280 Environmental Sensor initialization failed\n\r");
}
returnOverSamplingValue = Environmental_setOverSamplingPressure(xdkEnvironmental_BME280_Handle,ENVIRONMENTAL_BME280_OVERSAMP_2X);
if (RETCODE_OK != returnOverSamplingValue) {
printf("Configuring pressure oversampling failed \n\r");
}
returnFilterValue = Environmental_setFilterCoefficient(xdkEnvironmental_BME280_Handle,ENVIRONMENTAL_BME280_FILTER_COEFF_2);
if (RETCODE_OK != returnFilterValue) {
printf("Configuring pressure filter coefficient failed \n\r");
}
}
Finally we declared the main part of the program where we need to call all the function that we previously defined. Also define the timers.
Due to the fact that the environment sensor is attached to the board inside the XDK housing, it measures the temperature inside the housing. This leads to temperatures that deviate from the actual environment temperature, because the XDK’s housing temperature increased on runtime. This also affects the relative humidity, since it depends on the output of the environment sensor’s temperature sensor.
To get more usable temperature values, it is recommended to configure an offset that is applied to the temperature after reading. The following code snippet configures an offset of -5000 to compensate the temperature data by reducing it statically by 5 Kelvin.
This way, the original data can be stored in another variable if neccessary, before it is compensated. Note that the function for compensation requires the entire BME Data struct, as the relative humidity will be adjusted as well.
The following code will immediately return the compensated data: