bme680-rust/examples/reading_temperature.rs

65 lines
2.2 KiB
Rust
Raw Normal View History

2018-05-25 20:38:24 +00:00
extern crate bme680;
2018-05-18 12:57:34 +00:00
extern crate embedded_hal;
2018-05-18 20:12:42 +00:00
extern crate env_logger;
2018-05-18 12:57:34 +00:00
extern crate linux_embedded_hal as hal;
#[macro_use]
extern crate log;
2018-05-18 12:57:34 +00:00
2018-05-25 20:38:24 +00:00
use bme680::*;
use embedded_hal::blocking::i2c;
2018-05-18 12:57:34 +00:00
use hal::*;
use std::result;
use std::thread;
2018-05-18 12:57:34 +00:00
use std::time::Duration;
fn main() -> result::Result<
(),
Bme680Error<<hal::I2cdev as i2c::Read>::Error, <hal::I2cdev as i2c::Write>::Error>,
> {
2018-05-18 20:12:42 +00:00
env_logger::init();
2018-05-18 12:57:34 +00:00
let i2c = I2cdev::new("/dev/i2c-1").unwrap();
let mut dev = Bme680_dev::init(i2c, Delay {}, I2CAddress::Primary, 25)?;
2018-05-18 12:57:34 +00:00
let mut sensor_settings: SensorSettings = Default::default();
sensor_settings.tph_sett.os_hum = Some(OversamplingSetting::OS2x);
sensor_settings.tph_sett.os_pres = Some(OversamplingSetting::OS4x);
sensor_settings.tph_sett.os_temp = Some(OversamplingSetting::OS8x);
2018-05-20 20:08:34 +00:00
sensor_settings.tph_sett.filter = Some(2);
2018-05-18 12:57:34 +00:00
2018-05-28 17:56:57 +00:00
sensor_settings.gas_sett.run_gas_measurement = true;
2018-05-24 20:02:23 +00:00
sensor_settings.gas_sett.heatr_dur = Some(Duration::from_millis(1500));
2018-05-20 20:08:34 +00:00
sensor_settings.gas_sett.heatr_temp = Some(320);
2018-05-18 12:57:34 +00:00
let settings_sel = DesiredSensorSettings::OST_SEL | DesiredSensorSettings::OSP_SEL
| DesiredSensorSettings::OSH_SEL
| DesiredSensorSettings::GAS_SENSOR_SEL;
2018-05-18 12:57:34 +00:00
let profile_dur = dev.get_profile_dur(&sensor_settings)?;
2018-05-24 20:02:23 +00:00
info!("Duration {:?}", profile_dur);
info!("Setting sensor settings");
2018-05-18 12:57:34 +00:00
dev.set_sensor_settings(settings_sel, &sensor_settings)?;
info!("Setting forced power modes");
2018-05-18 12:57:34 +00:00
dev.set_sensor_mode(PowerMode::ForcedMode)?;
2018-05-20 20:08:34 +00:00
let sensor_settings = dev.get_sensor_settings(settings_sel);
info!("Sensor settings: {:?}", sensor_settings);
loop {
2018-05-21 14:26:14 +00:00
thread::sleep(Duration::from_millis(5000));
2018-05-20 20:08:34 +00:00
let power_mode = dev.get_sensor_mode();
info!("Sensor power mode: {:?}", power_mode);
info!("Setting forced power modes");
dev.set_sensor_mode(PowerMode::ForcedMode)?;
info!("Retrieving sensor data");
2018-05-24 20:02:23 +00:00
let (data, _state) = dev.get_sensor_data()?;
info!("Sensor Data {:?}", data);
2018-05-21 14:26:14 +00:00
info!("Temperature {}°C", data.temperature_celsius());
info!("Pressure {}hPa", data.pressure_hpa());
info!("Humidity {}%", data.humidity_percent());
info!("Gas Resistence {}Ω", data.gas_resistance_ohm());
}
2018-05-18 12:57:34 +00:00
}