sht3x-i2c (community library)

Summary

Name Value
Name sht3x-i2c
Version 1.0.0
Installs 5417
License Apache License, Version 2.0
Author Mariano Goluboff
URL the URL of the project, like https://github.com/particle-iot/sht3x-i2c
Repository git repository for the project, like https://github.com/particle-iot/sht3x-i2c
Download .tar.gz

Library for SHT31 I2C sensor This library makes it easy to get temperature and humidity from the SHT31 sensor using I2C.

Example Build Testing

Device OS Version:

This table is generated from an automated build. Success only indicates that the code compiled successfully.

Library Read Me

This content is provided by the library maintainer and has not been validated or approved.

sht3x-i2c Library

A library to interface a Particle device to an SHT31 temperature and humidity sensor using I2C

Usage

The SHT31 has two modes that can be used for reading temperature and humidity:

  • Single Shot: the Particle device will send a command to the sensor, wait for the measurement to complete, and then read the values.
  • Periodic: the Particle device will set the sensor to continuously measure temperature and humidity, which will be available to read at any time.
Which one should you use?

The Single Shot uses less power, as the sensor goes into idle mode while not measuring. However, the disadvantage is that getting a measurement takes longer since there is a wait time that is required between the command and the time the data is available to be retrieved.

In Periodic mode, data is available to be read immediately. However, this mode uses more power as the sensor is continuously making measurements.

Tracker

Connect the TX/RX of the Asset Tracker SOM or the M8 connector on TrackerOne. Note that these pins are multiplexed between the UART and the Wire3 I2C port.

Some SHT31 boards already include pull-up resistors on SCL and SDA. If your board doesn't include them, make sure to connect 4.7k pull-up resostors on both I2C lines to 3.3V.

If using TrackerOne, the available power is 5V on CAN_5V pin. Since the I/O is not 3.3V compliant, you will need to use a DC to DC converter to connect the power of the SHT31 sensor to 3.3V.

See the example in periodic/main.cpp for how to retrieve the temperature and humidity and insert it into the location publish object. This will result in the values being stored in the database along with the location of the Tracker.

#include "Particle.h"

#include "tracker_config.h"
#include "tracker.h"
#include "sht3x-i2c.h"

SYSTEM_THREAD(ENABLED);
SYSTEM_MODE(SEMI_AUTOMATIC);

PRODUCT_ID(TRACKER_PRODUCT_ID);
PRODUCT_VERSION(TRACKER_PRODUCT_VERSION);

SerialLogHandler logHandler(115200, LOG_LEVEL_TRACE, {
{ "app.gps.nmea", LOG_LEVEL_INFO },
{ "app.gps.ubx",  LOG_LEVEL_INFO },
{ "ncp.at", LOG_LEVEL_INFO },
{ "net.ppp.client", LOG_LEVEL_INFO },
});

Sht3xi2c sensor(Wire3);

void loc_gen_cb(JSONWriter &writer, LocationPoint &point, const void *context)
{
double temp, humid;

if (sensor.get_reading(&temp, &humid) == 0)
{
writer.name("sh31_temp").value(temp);
writer.name("sh31_humid").value(humid);
}
}

void setup()
{
Tracker::instance().init();
Tracker::instance().location.regLocGenCallback(loc_gen_cb);

pinMode(CAN_PWR, OUTPUT);       // Turn on 5V output on M8 connector
digitalWrite(CAN_PWR, HIGH);    // Turn on 5V output on M8 connector
delay(500);

sensor.begin(CLOCK_SPEED_400KHZ);
sensor.start_periodic();

Particle.connect();
}

void loop()
{
Tracker::instance().loop();
}

Boron/Argon

Connect the I2C bus of both devices (SCL and SDA), as well as 3.3V and GND. Some SHT31 boards already include pull-up resistors on SCL and SDA. If your board doesn't include them, make sure to connect 4.7k pull-up resistors on both I2C lines to 3.3V.

See the example in single-shot.ino for how to retrieve the temperature and humidity and print it to the serial port.

#include "Particle.h"
#include "sht3x-i2c.h"

SerialLogHandler logHandler(LOG_LEVEL_INFO);

Sht3xi2c sensor(Wire);

void setup()
{
sensor.begin(CLOCK_SPEED_400KHZ);
}

void loop()
{
static uint32_t timer = System.uptime();
double temp, humid;

if (System.uptime() - timer > 5)
{
timer = System.uptime();
if (sensor.single_shot(&temp, &humid) == 0)
{
Log.info("Temperature: %.2f, Humidity: %.2f", temp, humid);
}
}
}

Browse Library Files