199 lines
4.7 KiB
C
Raw Normal View History

2021-05-26 12:06:51 +02:00
#pragma once
//
// FILE: SHT85.h
// AUTHOR: Rob Tillaart
2023-09-21 19:10:25 +02:00
// VERSION: 0.5.1
2021-05-26 12:06:51 +02:00
// DATE: 2021-02-10
// PURPOSE: Arduino library for the SHT85 temperature and humidity sensor
// https://nl.rs-online.com/web/p/temperature-humidity-sensor-ics/1826530
// URL: https://github.com/RobTillaart/SHT85
//
2022-11-24 14:11:40 +01:00
// keep lib in sync with https://github.com/RobTillaart/SHT31
2021-12-28 14:21:26 +01:00
//
2023-04-06 16:54:56 +02:00
// ALWAYS check datasheet for connections.
//
2022-11-24 14:11:40 +01:00
// TOPVIEW SHT85
// +-------+
// +-----\ | SDA 4 -----
// | +-+ ----+ GND 3 -----
// | +-+ ----+ +5V 2 -----
// +-----/ | SCL 1 -----
// +-------+
2021-05-26 12:06:51 +02:00
#include "Arduino.h"
#include "Wire.h"
2023-09-21 19:10:25 +02:00
#define SHT_LIB_VERSION (F("0.5.1"))
2021-12-28 14:21:26 +01:00
#define SHT85_LIB_VERSION SHT_LIB_VERSION
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
#ifndef SHT_DEFAULT_ADDRESS
2022-01-17 21:15:55 +01:00
#define SHT_DEFAULT_ADDRESS 0x44
#endif
2021-05-26 12:06:51 +02:00
2022-11-24 14:11:40 +01:00
// fields readStatus
2021-12-28 14:21:26 +01:00
#define SHT_STATUS_ALERT_PENDING (1 << 15)
#define SHT_STATUS_HEATER_ON (1 << 13)
#define SHT_STATUS_HUM_TRACK_ALERT (1 << 11)
#define SHT_STATUS_TEMP_TRACK_ALERT (1 << 10)
#define SHT_STATUS_SYSTEM_RESET (1 << 4)
#define SHT_STATUS_COMMAND_STATUS (1 << 1)
#define SHT_STATUS_WRITE_CRC_STATUS (1 << 0)
2021-05-26 12:06:51 +02:00
2022-11-24 14:11:40 +01:00
// error codes
2021-12-28 14:21:26 +01:00
#define SHT_OK 0x00
#define SHT_ERR_WRITECMD 0x81
#define SHT_ERR_READBYTES 0x82
#define SHT_ERR_HEATER_OFF 0x83
#define SHT_ERR_NOT_CONNECT 0x84
#define SHT_ERR_CRC_TEMP 0x85
#define SHT_ERR_CRC_HUM 0x86
#define SHT_ERR_CRC_STATUS 0x87
#define SHT_ERR_HEATER_COOLDOWN 0x88
#define SHT_ERR_HEATER_ON 0x89
2023-05-09 12:44:18 +02:00
#define SHT_ERR_SERIAL 0x8A
2021-05-26 12:06:51 +02:00
2021-08-24 19:59:51 +02:00
class SHT
2021-05-26 12:06:51 +02:00
{
public:
2023-09-21 16:40:54 +02:00
SHT(TwoWire *wire = &Wire);
2021-05-26 12:06:51 +02:00
#if defined(ESP8266) || defined(ESP32)
2023-04-06 16:54:56 +02:00
bool begin(const uint8_t address, uint8_t dataPin, uint8_t clockPin);
2022-11-24 14:11:40 +01:00
// use SHT_DEFAULT_ADDRESS
2023-04-06 16:54:56 +02:00
bool begin(const uint8_t dataPin, const uint8_t clockPin);
2021-05-26 12:06:51 +02:00
#endif
2023-04-06 16:54:56 +02:00
2023-09-21 16:40:54 +02:00
bool begin(const uint8_t address = SHT_DEFAULT_ADDRESS);
2023-04-06 16:54:56 +02:00
uint8_t getType();
// SYNCHRONOUS INTERFACE
// read blocks 4 or 15 milliseconds + actual read + math
bool read(bool fast = true);
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// ASYNCHRONOUS INTERFACE
bool requestData(bool fast = true);
bool dataReady(bool fast = true);
bool readData(bool fast = true);
uint32_t lastRequest();
2021-08-24 19:59:51 +02:00
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// STATUS
2022-11-24 14:11:40 +01:00
// check sensor is reachable over I2C
2023-04-06 16:54:56 +02:00
bool isConnected();
2021-05-26 12:06:51 +02:00
2022-11-24 14:11:40 +01:00
// details see datasheet; summary in SHT85.cpp file
2021-05-26 12:06:51 +02:00
uint16_t readStatus();
2022-11-24 14:11:40 +01:00
// lastRead is in milliSeconds since start
2023-04-06 16:54:56 +02:00
uint32_t lastRead();
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
bool reset(bool hard = false);
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// returns last error and clears error flag
int getError();
2021-12-28 14:21:26 +01:00
2023-04-06 16:54:56 +02:00
// HEATER
2022-11-24 14:11:40 +01:00
// do not use heater for long periods,
// use it for max 3 minutes to heat up
// and let it cool down at least 3 minutes.
2023-04-06 16:54:56 +02:00
void setHeatTimeout(uint8_t seconds);
uint8_t getHeatTimeout();
bool heatOn();
bool heatOff();
// is the sensor still heating up?
bool isHeaterOn();
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// TEMPERATURE & HUMIDITY
float getHumidity();
float getTemperature();
float getFahrenheit();
uint16_t getRawHumidity();
uint16_t getRawTemperature();
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// TEMPERATURE & HUMIDITY OFFSET
void setTemperatureOffset(float offset = 0);
float getTemperatureOffset();
void setHumidityOffset(float offset = 0);
float getHumidityOffset();
2021-05-26 12:06:51 +02:00
2021-08-07 12:34:52 +02:00
2021-08-24 19:59:51 +02:00
protected:
2021-08-07 12:34:52 +02:00
uint8_t crc8(const uint8_t *data, uint8_t len);
bool writeCmd(uint16_t cmd);
bool readBytes(uint8_t n, uint8_t *val);
2021-05-26 12:06:51 +02:00
TwoWire* _wire;
2021-08-24 18:45:23 +02:00
uint8_t _address;
2023-04-06 16:54:56 +02:00
uint8_t _heatTimeout; // seconds
2021-08-07 12:34:52 +02:00
uint32_t _lastRead;
2023-04-06 16:54:56 +02:00
uint32_t _lastRequest; // for async interface
uint32_t _heaterStart; // timestamp
uint32_t _heaterStop; // timestamp
2021-08-24 18:45:23 +02:00
bool _heaterOn;
2023-04-06 16:54:56 +02:00
uint8_t _type; // base class = 0
2021-05-26 12:06:51 +02:00
2021-08-07 12:34:52 +02:00
uint16_t _rawHumidity;
uint16_t _rawTemperature;
2021-05-26 12:06:51 +02:00
2023-04-06 16:54:56 +02:00
// offset in degrees Celsius
float _temperatureOffset = 0;
float _humidityOffset = 0;
2021-05-26 12:06:51 +02:00
uint8_t _error;
};
2021-08-24 19:59:51 +02:00
////////////////////////////////////////////////////////
//
2023-04-06 16:54:56 +02:00
// DERIVED CLASSES
2021-08-24 19:59:51 +02:00
//
class SHT30 : public SHT
{
public:
2023-09-21 16:40:54 +02:00
SHT30(TwoWire *wire = &Wire);
2021-08-24 19:59:51 +02:00
};
class SHT31 : public SHT
{
public:
2023-09-21 16:40:54 +02:00
SHT31(TwoWire *wire = &Wire);
2021-08-24 19:59:51 +02:00
};
class SHT35 : public SHT
{
public:
2023-09-21 16:40:54 +02:00
SHT35(TwoWire *wire = &Wire);
2021-08-24 19:59:51 +02:00
};
class SHT85 : public SHT
{
public:
2023-09-21 16:40:54 +02:00
SHT85(TwoWire *wire = &Wire);
2023-09-06 11:42:30 +02:00
// catch incorrect calls with an address, only 0x44 allowed, see #19
#if defined(ESP8266) || defined(ESP32)
bool begin(const uint8_t address, uint8_t dataPin, uint8_t clockPin);
#endif
2023-09-21 16:40:54 +02:00
bool begin(const uint8_t address = SHT_DEFAULT_ADDRESS);
2023-09-06 11:42:30 +02:00
2023-05-09 12:44:18 +02:00
// EXPERIMENTAL for 0.4.1
uint32_t GetSerialNumber();
2021-08-24 19:59:51 +02:00
};
2023-04-06 16:54:56 +02:00
// -- END OF FILE --
2021-12-28 14:21:26 +01:00