111 lines
2.9 KiB
C
Raw Normal View History

2020-11-27 11:33:55 +01:00
#pragma once
2019-02-18 14:01:41 +01:00
//
// FILE: SHT31.h
// AUTHOR: Rob Tillaart
2021-09-20 11:41:38 +02:00
// VERSION: 0.3.4
2019-02-18 14:01:41 +01:00
// DATE: 2019-02-08
2020-11-27 11:33:55 +01:00
// PURPOSE: Arduino library for the SHT31 temperature and humidity sensor
2019-02-18 14:01:41 +01:00
// https://www.adafruit.com/product/2857
2020-11-27 11:33:55 +01:00
// URL: https://github.com/RobTillaart/SHT31
2019-02-18 14:01:41 +01:00
//
2021-01-29 12:31:58 +01:00
2019-02-18 14:01:41 +01:00
#include "Arduino.h"
#include "Wire.h"
2021-01-29 12:31:58 +01:00
2021-09-20 11:41:38 +02:00
#define SHT31_LIB_VERSION (F("0.3.4"))
2021-01-29 12:31:58 +01:00
2020-11-27 11:33:55 +01:00
// fields readStatus
#define SHT31_STATUS_ALERT_PENDING (1 << 15)
#define SHT31_STATUS_HEATER_ON (1 << 13)
#define SHT31_STATUS_HUM_TRACK_ALERT (1 << 11)
#define SHT31_STATUS_TEMP_TRACK_ALERT (1 << 10)
#define SHT31_STATUS_SYSTEM_RESET (1 << 4)
#define SHT31_STATUS_COMMAND_STATUS (1 << 1)
#define SHT31_STATUS_WRITE_CRC_STATUS (1 << 0)
2019-02-18 14:01:41 +01:00
2021-01-29 12:31:58 +01:00
// error codes
#define SHT31_OK 0x00
#define SHT31_ERR_WRITECMD 0x81
#define SHT31_ERR_READBYTES 0x82
#define SHT31_ERR_HEATER_OFF 0x83
#define SHT31_ERR_NOT_CONNECT 0x84
#define SHT31_ERR_CRC_TEMP 0x85
#define SHT31_ERR_CRC_HUM 0x86
#define SHT31_ERR_CRC_STATUS 0x87
2021-08-24 16:01:55 +02:00
#define SHT31_ERR_HEATER_COOLDOWN 0x88
#define SHT31_ERR_HEATER_ON 0x89
2021-01-29 12:31:58 +01:00
2019-02-18 14:01:41 +01:00
class SHT31
{
public:
SHT31();
2020-11-27 11:33:55 +01:00
#if defined(ESP8266) || defined(ESP32)
bool begin(const uint8_t address, uint8_t dataPin, uint8_t clockPin);
#endif
2019-02-18 14:01:41 +01:00
bool begin(const uint8_t address);
2020-11-27 11:33:55 +01:00
bool begin(const uint8_t address, TwoWire *wire);
// blocks 15 milliseconds + actual read + math
2019-02-18 14:01:41 +01:00
bool read(bool fast = true);
2021-08-24 16:01:55 +02:00
// check sensor is reachable over I2C
2021-01-29 12:31:58 +01:00
bool isConnected();
2020-11-27 11:33:55 +01:00
// details see datasheet; summary in SHT31.cpp file
2019-02-18 14:01:41 +01:00
uint16_t readStatus();
2020-11-27 11:33:55 +01:00
// lastRead is in milliSeconds since start
2019-02-18 14:01:41 +01:00
uint32_t lastRead() { return _lastRead; };
2021-01-29 12:31:58 +01:00
bool reset(bool hard = false);
2019-03-05 18:45:36 +01:00
// do not use heater for long periods,
// use it for max 3 minutes to heat up
2021-08-24 16:01:55 +02:00
// and let it cool down at least 3 minutes.
2020-11-27 11:33:55 +01:00
void setHeatTimeout(uint8_t seconds);
2021-08-24 16:01:55 +02:00
uint8_t getHeatTimeout() { return _heatTimeout; };
;
2021-01-29 12:31:58 +01:00
bool heatOn();
bool heatOff();
bool isHeaterOn(); // is the sensor still heating up?
bool heatUp() { return isHeaterOn(); }; // will be obsolete in future
2019-02-18 14:01:41 +01:00
2021-08-06 19:16:44 +02:00
float getHumidity() { return rawHumidity * (100.0 / 65535); };
float getTemperature() { return rawTemperature * (175.0 / 65535) - 45; };
uint16_t getRawHumidity() {return rawHumidity ; };
uint16_t getRawTemperature() {return rawTemperature; };
2019-02-18 14:01:41 +01:00
2019-03-05 18:45:36 +01:00
// ASYNC INTERFACE
2021-01-29 12:31:58 +01:00
bool requestData();
2019-03-05 18:45:36 +01:00
bool dataReady();
2020-11-27 11:33:55 +01:00
bool readData(bool fast = true);
2019-03-05 18:45:36 +01:00
2021-01-29 12:31:58 +01:00
int getError(); // clears error flag
2019-02-18 14:01:41 +01:00
private:
2021-01-29 12:31:58 +01:00
uint8_t crc8(const uint8_t *data, uint8_t len);
bool writeCmd(uint16_t cmd);
bool readBytes(uint8_t n, uint8_t *val);
2020-11-27 11:33:55 +01:00
TwoWire* _wire;
2019-02-18 14:01:41 +01:00
2021-08-24 16:01:55 +02:00
uint8_t _address;
uint8_t _heatTimeout; // seconds
2019-02-18 14:01:41 +01:00
uint32_t _lastRead;
2019-03-05 18:45:36 +01:00
uint32_t _lastRequest; // for async interface
2020-11-27 11:33:55 +01:00
uint32_t _heaterStart;
2021-08-24 16:01:55 +02:00
uint32_t _heaterStop;
bool _heaterOn;
2020-11-27 11:33:55 +01:00
2021-08-06 19:16:44 +02:00
uint16_t rawHumidity;
uint16_t rawTemperature;
2021-01-29 12:31:58 +01:00
uint8_t _error;
2019-02-18 14:01:41 +01:00
};
2020-11-27 11:33:55 +01:00
// -- END OF FILE --