You can easily wire this breakout to any microcontroller, we'll be using an Arduino. For another kind of microcontroller, just make sure it has I2C, then port the code - its pretty simple stuff!
- Connect Vin to the power supply, 3-5V is fine. (red wire on STEMMA QT version) Use the same voltage that the microcontroller logic is based off of. For most Arduinos, that is 5V
- Connect GND to common power/data ground (black wire on STEMMA QT version)
- Connect the SCL pin to the I2C clock SCL pin on your Arduino. (yellow wire on STEMMA QT version) On an UNO & '328 based Arduino, this is also known as A5, on a Mega it is also known as digital 21 and on a Leonardo/Micro, digital 3
- Connect the SDA pin to the I2C data SDA pin on your Arduino. (blue wire on STEMMA QT version) On an UNO & '328 based Arduino, this is also known as A4, on a Mega it is also known as digital 20 and on a Leonardo/Micro, digital 2
The SHT31-D has a default I2C address of 0x44 which you can change to 0x45 by connecting the ADR pin to the VIN pin
Download Adafruit_SHT31
To begin reading sensor data, you will need to download the Adafruit SHT31 library from the Arduino library manager.
Open up the Arduino library manager:
Search for the Adafruit SHT31 library and install it
We also have a great tutorial on Arduino library installation at:
http://learn.adafruit.com/adafruit-all-about-arduino-libraries-install-use
Load Demo
Open up File->Examples->Adafruit_SHT31->SHT31test and upload to your Arduino wired up to the sensor
Thats it! Now open up the serial terminal window at 9600 speed to begin the test.
You can try breathing on the sensor to increase the humidity. The sensor reacts very fast!
Library Reference
The library we have is simple and easy to use
You can create the Adafruit_SHT31 object with:
Adafruit_SHT31 sht31 = Adafruit_SHT31();
There are no pins to set since you must use the I2C bus!
Then initialize the sensor with:
sht31.begin(0x44)
This function returns True if the sensor was found and responded correctly and False if it was not found
The 0x44 is the i2c address you have the sensor set up for. By default its 0x44, you can also adjust the sensor for 0x45 and then pass that value in
Once initialized, you can query the temperature in °C with
sht31.readTemperature()
Which will return floating point (decimal + fractional) temperature. You can convert to Fahrenheit by multiplying by 1.8 and adding 32 as you have learned in grade school!
Reading the humidity is equally simple. Call
sht31.readHumidity()
to read the humidity also as a floating point value between 0 and 100 (this reads % humidity)
We also have a few helper functions. Want to soft-reset the sensor? Use
sht31.reset()
There's also a heater built into the sensor, used to heat/evaporate any condensation. You can turn it on or off with
sht31.heater(true) sht31.heater(false)
Page last edited March 08, 2024
Text editor powered by tinymce.