2023-10-24 16:50:18 +02:00

3.8 KiB

Arduino CI Arduino-lint JSON check GitHub issues

License: MIT GitHub release PlatformIO Registry

DHT12

Arduino library for I2C DHT12 temperature and humidity sensor.

Description

The DHT12 is an I2C temperature and humidity sensor.

The constructor is called only with a TwoWire object (Wire, Wire1 etc) as the device has a fixed address. The user should call Wire.begin() in setup before calling the begin() function.

Thereafter one has to call the read() function to do the actual reading, and with getTemperature() and getHumidity() to get the read values. Calling these latter again will return the same values until a new read() is called.

I2C

The DHT12 has a fixed I2C address of 0x5C. To use multiple DHT12's one need an I2C multiplexer like PCA9548 or TCA9548.

The DHT12 should work up to 400 KHz however this is not tested (yet).

Interface

#include "DHT12.h"

Constructor

  • DHT12(TwoWire *wire = &Wire) constructor, using a specific Wire (I2C bus). Default is set to Wire.
  • bool begin() initializer for non ESP32. Returns true if connected.
  • bool isConnected() returns true if the address of the DHT12 can be seen on the I2C bus. (since 0.3.2)

Core

  • int8_t read() read the sensor and store the values internally. It returns the status of the read which should be 0.
  • float getHumidity() returns last Humidity read, or -999 in case of error.
  • float getTemperature() returns last Temperature read, or -999 in case of error.
  • uint32_t lastRead() returns the timestamp of the last successful read in milliseconds since startup. If zero there has been no read() called yet.

Offset

  • void setHumOffset(float offset = 0) set an offset to calibrate (1st order) the sensor. Default offset is 0.
  • float getHumOffset() return current humidity offset, default 0.
  • void setTempOffset(float offset = 0) set an offset to calibrate (1st order) the sensor. Default offset is 0.
  • float getTempOffset() return current temperature offset, default 0.

Future

Must

  • documentation
    • related?

Should

  • test at different I2C speeds
    • 400 KHz should be possible.
  • add examples.

Could

  • check for optimizations. although I2C overhead is much more.
  • add void setIgnoreChecksum(bool = false) ignore checksum flag speeds up communication a bit
  • add bool getIgnoreChecksum() get status. For completeness.
  • investigate if it is possible to extract temp and hum separately
    • faster?
  • add void suppressErrorReads(bool) prevents the -999, returns previous value
  • add bool getSuppressError()

Wont

Support

If you appreciate my libraries, you can support the development and maintenance. Improve the quality of the libraries by providing issues and Pull Requests, or donate through PayPal or GitHub sponsors.

Thank you,