2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/DS1821/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-12-17 14:11:19 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/DS1821/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/DS1821/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/DS1821/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/DS1821/actions/workflows/jsoncheck.yml)
|
2023-10-25 20:42:40 +02:00
|
|
|
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/DS1821.svg)](https://github.com/RobTillaart/DS1821/issues)
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/DS1821/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/DS1821.svg?maxAge=3600)](https://github.com/RobTillaart/DS1821/releases)
|
2023-10-25 20:42:40 +02:00
|
|
|
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/DS1821.svg)](https://registry.platformio.org/libraries/robtillaart/DS1821)
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
# DS1821
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
Arduino library for DS1821 temperature sensor (experimental).
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-05-28 13:24:52 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Description
|
|
|
|
|
|
|
|
The DS1821 is a temperature sensor that uses the oneWire protocol.
|
|
|
|
This library supports one sensor per pin.
|
|
|
|
As this library is tested minimally please consider it experimental.
|
|
|
|
|
2023-10-25 20:34:23 +02:00
|
|
|
The sensor is hard to get however still available on the Internet.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-05-28 13:24:52 +02:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Interface (temperature sensor)
|
|
|
|
|
2023-10-25 20:34:23 +02:00
|
|
|
```cpp
|
|
|
|
#include "DS1821.h"
|
|
|
|
```
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
The interface of the library is an async interface so there are no blocking calls.
|
|
|
|
|
|
|
|
The return value **DS1821_RESET_ERROR == -999** means that the oneWire bus failed to reset.
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
- **DS1821(OneWire\* ow)** initializes the library with a reference to a oneWire object.
|
2021-01-29 12:31:58 +01:00
|
|
|
See examples.
|
|
|
|
- **int requestTemperature()** this call will trigger a conversion of temperature,
|
2021-12-17 14:11:19 +01:00
|
|
|
however it does not read the temperature. May return **DS1821_RESET_ERROR**.
|
|
|
|
- **int requestContinuous()**
|
|
|
|
- **int stopContinuous()**
|
2021-01-29 12:31:58 +01:00
|
|
|
- **int conversionReady()** when the conversion is ready it returns 1, else 0.
|
|
|
|
May return **DS1821_RESET_ERROR**
|
|
|
|
- **float readTemperature()** when conversion is ready, one can fetch the temperature.
|
|
|
|
May return **DS1821_RESET_ERROR**
|
|
|
|
- **int error()** read the last error.
|
|
|
|
|
|
|
|
The low / high functions can be used to monitor if a threshold has been exceeded
|
|
|
|
between reads of the temperature.
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
- **int setLow(int8_t lo)** set low (OFF) threshold temperature.
|
|
|
|
- **int getLow()** read back from configuration.
|
|
|
|
- **int setHigh(int8_t hi)** set high (ON) threshold temperature.
|
|
|
|
- **int getHigh()** read back from configuration.
|
|
|
|
- **int getHighFlag()** flag is set if temperature has exceeded high threshold.
|
|
|
|
- **int clrHighFlag()** reset the high threshold flag.
|
|
|
|
- **int getLowFlag()** flag is set if temperature has exceeded low threshold.
|
|
|
|
- **int clrLowFlag()** reset the low threshold flag.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Interface (thermostat)
|
|
|
|
|
|
|
|
Please read datasheet.
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
The DS1821 can be setup as a stand-alone thermostat with a high level and low level.
|
2021-01-29 12:31:58 +01:00
|
|
|
In this mode the DS1821 uses the **DQ** pin to switch a device ON when the high level
|
|
|
|
is exceeded and switches OFF when the low level is reached.
|
|
|
|
This prevents too frequent toggling which would happen if only one temperature was used.
|
|
|
|
To configure the thermostat mode please check the example.
|
|
|
|
|
|
|
|
The library provides the following functions for configuring the Thermostat mode
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
- **int setOneWireMode(uint8_t VDD, uint8_t DQ)**
|
2021-01-29 12:31:58 +01:00
|
|
|
This function puts a DS1821 in Thermostat mode back into oneWire mode.
|
|
|
|
DQ must be the same as oneWire(pin).
|
|
|
|
VDD is the voltage controlling pin of the sensor.
|
2021-12-17 14:11:19 +01:00
|
|
|
- **int setThermostatMode()** sets the flag in the config register to start in
|
2021-01-29 12:31:58 +01:00
|
|
|
Thermostat mode next restart.
|
|
|
|
|
|
|
|
The polarity functions are also available in temperature sensor mode,
|
|
|
|
however they have no effect in that mode.
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
- **int setPolarity(int activeState)** When in thermostat mode the DQ pin controls e.g.
|
|
|
|
a fan or a motor. ActivState defines which value is ON and OFF.
|
|
|
|
- **int getPolarity()** reads back polarity from the device.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
The Low / High values set in sensor mode gives the DS1821 the thresholds
|
|
|
|
to toggle the DQ line in the thermostat mode.
|
|
|
|
|
2021-05-28 13:24:52 +02:00
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
## Operation
|
|
|
|
|
|
|
|
See examples.
|
|
|
|
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
## Future
|
|
|
|
|
2023-10-25 20:34:23 +02:00
|
|
|
#### Must
|
|
|
|
|
|
|
|
- update documentation
|
|
|
|
|
|
|
|
#### Should
|
|
|
|
|
|
|
|
#### Could
|
|
|
|
|
|
|
|
#### Wont
|
|
|
|
|
2021-12-17 14:11:19 +01:00
|
|
|
- updates only on request
|
2021-01-29 12:31:58 +01:00
|
|
|
- Get new sensors to test test test...
|
|
|
|
- merge clrLowFlag() into getLowFlag() ? high idem?
|
2023-10-25 20:34:23 +02:00
|
|
|
|
|
|
|
|
|
|
|
## 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,
|
2021-01-29 12:31:58 +01:00
|
|
|
|