GY-63_MS5611/libraries/SHT31/SHT31.h

118 lines
3.2 KiB
C
Raw Normal View History

2020-11-27 05:33:55 -05:00
#pragma once
2019-02-18 08:01:41 -05:00
//
// FILE: SHT31.h
// AUTHOR: Rob Tillaart
2022-01-18 06:30:33 -05:00
// VERSION: 0.3.6
2019-02-18 08:01:41 -05:00
// DATE: 2019-02-08
2020-11-27 05:33:55 -05:00
// PURPOSE: Arduino library for the SHT31 temperature and humidity sensor
2019-02-18 08:01:41 -05:00
// https://www.adafruit.com/product/2857
2020-11-27 05:33:55 -05:00
// URL: https://github.com/RobTillaart/SHT31
2019-02-18 08:01:41 -05:00
//
2021-01-29 06:31:58 -05:00
2019-02-18 08:01:41 -05:00
#include "Arduino.h"
#include "Wire.h"
2021-01-29 06:31:58 -05:00
2022-01-18 06:30:33 -05:00
#define SHT31_LIB_VERSION (F("0.3.6"))
2021-01-29 06:31:58 -05:00
2022-01-18 06:30:33 -05:00
#ifndef SHT_DEFAULT_ADDRESS
#define SHT_DEFAULT_ADDRESS 0x44
#endif
2020-11-27 05:33:55 -05: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 08:01:41 -05:00
2021-01-29 06:31:58 -05: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 10:01:55 -04:00
#define SHT31_ERR_HEATER_COOLDOWN 0x88
#define SHT31_ERR_HEATER_ON 0x89
2021-01-29 06:31:58 -05:00
2019-02-18 08:01:41 -05:00
class SHT31
{
public:
SHT31();
2020-11-27 05:33:55 -05:00
#if defined(ESP8266) || defined(ESP32)
bool begin(const uint8_t address, uint8_t dataPin, uint8_t clockPin);
2022-01-18 06:30:33 -05:00
// use SHT_DEFAULT_ADDRESS
bool begin(const uint8_t dataPin, const uint8_t clockPin);
2020-11-27 05:33:55 -05:00
#endif
2022-01-18 06:30:33 -05:00
bool begin(const uint8_t address, TwoWire *wire = &Wire);
// use SHT_DEFAULT_ADDRESS
bool begin(TwoWire *wire = &Wire);
2020-11-27 05:33:55 -05:00
// blocks 15 milliseconds + actual read + math
2019-02-18 08:01:41 -05:00
bool read(bool fast = true);
2021-08-24 10:01:55 -04:00
// check sensor is reachable over I2C
2021-01-29 06:31:58 -05:00
bool isConnected();
2020-11-27 05:33:55 -05:00
// details see datasheet; summary in SHT31.cpp file
2019-02-18 08:01:41 -05:00
uint16_t readStatus();
2020-11-27 05:33:55 -05:00
// lastRead is in milliSeconds since start
2019-02-18 08:01:41 -05:00
uint32_t lastRead() { return _lastRead; };
2021-01-29 06:31:58 -05:00
bool reset(bool hard = false);
2019-03-05 12:45:36 -05:00
// do not use heater for long periods,
// use it for max 3 minutes to heat up
2021-08-24 10:01:55 -04:00
// and let it cool down at least 3 minutes.
2020-11-27 05:33:55 -05:00
void setHeatTimeout(uint8_t seconds);
2021-08-24 10:01:55 -04:00
uint8_t getHeatTimeout() { return _heatTimeout; };
2021-01-29 06:31:58 -05: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 08:01:41 -05:00
2022-01-18 06:30:33 -05:00
float getHumidity() { return _rawHumidity * (100.0 / 65535); };
float getTemperature() { return _rawTemperature * (175.0 / 65535) - 45; };
float getFahrenheit() { return _rawTemperature * (63.0 /13107.0) - 49; };
uint16_t getRawHumidity() { return _rawHumidity; };
uint16_t getRawTemperature() { return _rawTemperature; };
2019-02-18 08:01:41 -05:00
2019-03-05 12:45:36 -05:00
// ASYNC INTERFACE
2021-01-29 06:31:58 -05:00
bool requestData();
2019-03-05 12:45:36 -05:00
bool dataReady();
2020-11-27 05:33:55 -05:00
bool readData(bool fast = true);
2019-03-05 12:45:36 -05:00
2021-01-29 06:31:58 -05:00
int getError(); // clears error flag
2019-02-18 08:01:41 -05:00
private:
2021-01-29 06:31:58 -05: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 05:33:55 -05:00
TwoWire* _wire;
2019-02-18 08:01:41 -05:00
2021-08-24 10:01:55 -04:00
uint8_t _address;
uint8_t _heatTimeout; // seconds
2019-02-18 08:01:41 -05:00
uint32_t _lastRead;
2019-03-05 12:45:36 -05:00
uint32_t _lastRequest; // for async interface
2020-11-27 05:33:55 -05:00
uint32_t _heaterStart;
2021-08-24 10:01:55 -04:00
uint32_t _heaterStop;
bool _heaterOn;
2020-11-27 05:33:55 -05:00
2022-01-18 06:30:33 -05:00
uint16_t _rawHumidity;
uint16_t _rawTemperature;
2021-01-29 06:31:58 -05:00
uint8_t _error;
2019-02-18 08:01:41 -05:00
};
2020-11-27 05:33:55 -05:00
// -- END OF FILE --