2020-05-07 09:53:25 +02:00
|
|
|
#pragma once
|
2017-12-12 13:16:58 +01:00
|
|
|
//
|
|
|
|
// FILE: AM232X.h
|
|
|
|
// AUTHOR: Rob Tillaart
|
2022-02-07 17:43:28 +01:00
|
|
|
// PURPOSE: AM232X Temperature and Humidity sensor library for Arduino
|
2023-01-12 17:33:55 +01:00
|
|
|
// VERSION: 0.4.5
|
2020-05-07 09:53:25 +02:00
|
|
|
// URL: https://github.com/RobTillaart/AM232X
|
2017-12-12 13:16:58 +01:00
|
|
|
//
|
2022-01-06 14:05:38 +01:00
|
|
|
// AM232X PIN layout AM2315 COLOR
|
|
|
|
// ============================================
|
|
|
|
// bottom view DESCRIPTION COLOR
|
2021-01-29 12:31:58 +01:00
|
|
|
// +---+
|
2022-01-06 14:05:38 +01:00
|
|
|
// |o | VDD RED
|
|
|
|
// |o | SDA YELLOW
|
|
|
|
// |o | GND BLACK
|
|
|
|
// |o | SCL GREY
|
2021-01-29 12:31:58 +01:00
|
|
|
// +---+
|
2022-01-06 14:05:38 +01:00
|
|
|
//
|
|
|
|
// do not forget pull up resistors between SDA, SCL and VDD.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
2017-12-12 13:16:58 +01:00
|
|
|
#include "Arduino.h"
|
2021-01-29 12:31:58 +01:00
|
|
|
#include "Wire.h"
|
|
|
|
|
|
|
|
|
2023-01-12 17:33:55 +01:00
|
|
|
#define AM232X_LIB_VERSION (F("0.4.5"))
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
#define AM232X_OK 0
|
|
|
|
#define AM232X_ERROR_UNKNOWN -10
|
|
|
|
#define AM232X_ERROR_CONNECT -11
|
|
|
|
#define AM232X_ERROR_FUNCTION -12
|
|
|
|
#define AM232X_ERROR_ADDRESS -13
|
|
|
|
#define AM232X_ERROR_REGISTER -14
|
|
|
|
#define AM232X_ERROR_CRC_1 -15
|
|
|
|
#define AM232X_ERROR_CRC_2 -16
|
|
|
|
#define AM232X_ERROR_WRITE_DISABLED -17
|
|
|
|
#define AM232X_ERROR_WRITE_COUNT -18
|
|
|
|
#define AM232X_MISSING_BYTES -19
|
2022-01-06 14:05:38 +01:00
|
|
|
#define AM232X_READ_TOO_FAST -20
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2017-12-12 13:16:58 +01:00
|
|
|
|
|
|
|
/*
|
2021-02-03 17:20:20 +01:00
|
|
|
from datasheet
|
|
|
|
0x80: not support function code
|
|
|
|
0x81: Read an illegal address
|
|
|
|
0x82: write data beyond the scope
|
|
|
|
0x83: CRC checksum error
|
|
|
|
0x84: Write disabled
|
2017-12-12 13:16:58 +01:00
|
|
|
*/
|
|
|
|
|
2022-06-18 09:51:07 +02:00
|
|
|
|
|
|
|
// optionally detect out of range values.
|
|
|
|
// occurs seldom so not enabled by default.
|
|
|
|
// #define AM232X_VALUE_OUT_OF_RANGE
|
|
|
|
#define AM232X_HUMIDITY_OUT_OF_RANGE -100
|
|
|
|
#define AM232X_TEMPERATURE_OUT_OF_RANGE -101
|
|
|
|
|
|
|
|
|
|
|
|
// allows to overrule AM232X_INVALID_VALUE e.g. to prevent spike in graphs.
|
|
|
|
#ifndef AM232X_INVALID_VALUE
|
|
|
|
#define AM232X_INVALID_VALUE -999
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
2017-12-12 13:16:58 +01:00
|
|
|
class AM232X
|
|
|
|
{
|
2021-04-07 13:31:22 +02:00
|
|
|
public:
|
2022-06-17 12:53:44 +02:00
|
|
|
explicit AM232X(TwoWire *wire = &Wire);
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-06-17 12:53:44 +02:00
|
|
|
#if defined(ESP8266) || defined(ESP32)
|
|
|
|
bool begin(const uint8_t dataPin, const uint8_t clockPin);
|
2020-11-27 11:10:47 +01:00
|
|
|
#endif
|
2022-06-17 12:53:44 +02:00
|
|
|
bool begin();
|
|
|
|
// datasheet 8.2 - wake up is min 800 us max 3000 us
|
|
|
|
bool isConnected(uint16_t timeout = 3000);
|
|
|
|
|
|
|
|
int read();
|
|
|
|
// lastRead is in MilliSeconds since start sketch
|
|
|
|
uint32_t lastRead() { return _lastRead; };
|
|
|
|
|
|
|
|
// set readDelay to 0 will reset to datasheet values
|
|
|
|
uint16_t getReadDelay() { return _readDelay; };
|
|
|
|
void setReadDelay(uint16_t rd = 0);
|
|
|
|
|
|
|
|
// negative return values are errors
|
|
|
|
int getModel();
|
|
|
|
int getVersion();
|
|
|
|
uint32_t getDeviceID();
|
|
|
|
|
|
|
|
int getStatus();
|
|
|
|
int getUserRegisterA();
|
|
|
|
int getUserRegisterB();
|
|
|
|
|
|
|
|
int setStatus(uint8_t value);
|
|
|
|
int setUserRegisterA(int value);
|
|
|
|
int setUserRegisterB(int value);
|
|
|
|
|
|
|
|
float getHumidity();
|
|
|
|
float getTemperature();
|
|
|
|
|
|
|
|
// adding offsets works well in normal range
|
|
|
|
// might introduce under- or overflow at the ends of the sensor range
|
|
|
|
void setHumOffset(float offset = 0) { _humOffset = offset; };
|
|
|
|
void setTempOffset(float offset = 0) { _tempOffset = offset; };
|
|
|
|
float getHumOffset() { return _humOffset; };
|
|
|
|
float getTempOffset() { return _tempOffset; };
|
|
|
|
|
2022-06-18 09:51:07 +02:00
|
|
|
// suppress error values of -999 => check return value of read() instead
|
|
|
|
bool getSuppressError() { return _suppressError; };
|
|
|
|
void setSuppressError(bool b) { _suppressError = b; };
|
2022-10-27 17:22:29 +02:00
|
|
|
|
2022-06-17 12:53:44 +02:00
|
|
|
bool wakeUp() { return isConnected(); };
|
|
|
|
|
|
|
|
protected:
|
|
|
|
uint8_t _bits[8]; // buffer to hold raw data
|
|
|
|
float _humidity = 0.0;
|
|
|
|
float _temperature = 0.0;
|
|
|
|
float _humOffset = 0.0;
|
|
|
|
float _tempOffset = 0.0;
|
|
|
|
uint32_t _lastRead = 0;
|
|
|
|
uint16_t _readDelay = 2000;
|
|
|
|
|
2022-06-18 09:51:07 +02:00
|
|
|
bool _suppressError = false;
|
2022-10-27 17:22:29 +02:00
|
|
|
|
2022-06-17 12:53:44 +02:00
|
|
|
int _readRegister(uint8_t reg, uint8_t cnt);
|
|
|
|
int _writeRegister(uint8_t reg, uint8_t cnt, int16_t value);
|
|
|
|
int _getData(uint8_t length);
|
|
|
|
|
|
|
|
uint16_t _crc16(uint8_t *ptr, uint8_t len);
|
|
|
|
|
|
|
|
TwoWire* _wire;
|
2017-12-12 13:16:58 +01:00
|
|
|
};
|
|
|
|
|
2022-01-06 14:05:38 +01:00
|
|
|
|
2022-06-17 12:53:44 +02:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// AM232X derived classes
|
|
|
|
//
|
|
|
|
class AM2320 : public AM232X
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
AM2320(TwoWire *wire = &Wire);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class AM2321 : public AM232X
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
AM2321(TwoWire *wire = &Wire);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class AM2322 : public AM232X
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
AM2322(TwoWire *wire = &Wire);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-11-27 11:10:47 +01:00
|
|
|
// -- END OF FILE --
|
2022-01-06 14:05:38 +01:00
|
|
|
|