mirror of
https://github.com/RobTillaart/Arduino.git
synced 2024-10-03 18:09:02 -04:00
161 lines
4.9 KiB
Markdown
161 lines
4.9 KiB
Markdown
|
|
[![Arduino CI](https://github.com/RobTillaart/AD524X/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
|
[![Arduino-lint](https://github.com/RobTillaart/AD524X/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/AD524X/actions/workflows/arduino-lint.yml)
|
|
[![JSON check](https://github.com/RobTillaart/AD524X/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/AD524X/actions/workflows/jsoncheck.yml)
|
|
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/AD524X.svg)](https://github.com/RobTillaart/AD524X/issues)
|
|
|
|
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/AD524X/blob/master/LICENSE)
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/AD524X.svg?maxAge=3600)](https://github.com/RobTillaart/AD524X/releases)
|
|
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/AD524X.svg)](https://registry.platformio.org/libraries/robtillaart/AD524X)
|
|
|
|
|
|
# AD524X
|
|
|
|
Arduino class for I2C digital potentiometer AD5241 AD5242.
|
|
|
|
|
|
## Description
|
|
|
|
The AD5241 and AD5242 are digital potentiometers.
|
|
The AD5241 has one, the AD5242 has two potentiometers.
|
|
Both types have two output lines O1 and O2.
|
|
|
|
These digital potentiometers come in 10K, 100K and 1M
|
|
and can be set in 256 steps.
|
|
|
|
An important property of the devices is that they defaults
|
|
to their mid position at startup.
|
|
|
|
The library also defines AD524X_MIDPOINT == 127.
|
|
To be used to set to defined mid-point.
|
|
|
|
|
|
#### Related libraries
|
|
|
|
This library is related to
|
|
- https://github.com/RobTillaart/AD5245 single port digital potentiometer.
|
|
- https://github.com/RobTillaart/AD520X multi port digital potentiometer.
|
|
|
|
|
|
#### Compatibles (?)
|
|
|
|
The AD5243 (fixed address) and AD5248 (2 address pins) are very close but
|
|
not compatible with this library. See future.
|
|
|
|
|
|
## I2C address
|
|
|
|
The AD524X has two address lines to configure the I2C address. 0x2C - 0x2F
|
|
|
|
| Addr(dec)| Addr(Hex) | AD0 | AD1 |
|
|
|:--------:|:---------:|:-----:|:-----:|
|
|
| 44 | 0x2C | GND | GND |
|
|
| 45 | 0x2D | GND | +5V |
|
|
| 46 | 0x2E | +5V | GND |
|
|
| 47 | 0x2F | +5V | +5V |
|
|
|
|
|
|
## Interface
|
|
|
|
```cpp
|
|
#include "AD524X.h"
|
|
```
|
|
|
|
The library has a number of functions which are all quite straightforward.
|
|
One can get / set the value of (both) the potentiometer(s), and the O1 and O2 output lines.
|
|
|
|
|
|
#### Constructors
|
|
|
|
- **AD524X(uint8_t address, TwoWire \*wire = &Wire)** constructor base class,
|
|
creates an instance with 2 potentiometer.
|
|
This class does not distinguish between AD5241 and AD5242.
|
|
The developer is responsible for handling this correctly.
|
|
- **AD5241(uint8_t address, TwoWire \*wire = &Wire)** create an instance with 1 potentiometer.
|
|
- **AD5242(uint8_t address, TwoWire \*wire = &Wire)** create an instance with 2 potentiometer.
|
|
|
|
|
|
#### Wire initialization
|
|
|
|
- **bool begin(uint8_t sda, uint8_t scl)** ESP32 a.o initializing of Wire.
|
|
- **bool begin()** for UNO.
|
|
- **bool isConnected()** See if address set in constructor is on the bus.
|
|
|
|
|
|
#### Basic IO
|
|
|
|
- **uint8_t write(uint8_t rdac, uint8_t value)** set channel rdac 0/1 to value 0..255.
|
|
- **uint8_t write(uint8_t rdac, uint8_t value, uint8_t O1, uint8_t O2)** idem + set output lines O1 and O2 too.
|
|
- **uint8_t read(uint8_t rdac)** read back set value.
|
|
- **uint8_t setO1(uint8_t value = HIGH)** value = HIGH (default) or LOW.
|
|
- **uint8_t setO2(uint8_t value = HIGH)** value = HIGH (default) or LOW.
|
|
- **uint8_t getO1()** read back O1 line.
|
|
- **uint8_t getO2()** read back O2 line.
|
|
|
|
|
|
#### Misc
|
|
|
|
- **uint8_t zeroAll()** sets potentiometer's to 0 and I/O to LOW.
|
|
- **uint8_t reset()** sets potentiometer's to midpoint == 127 and I/O to LOW. (startup default)
|
|
- **uint8_t midScaleReset(uint8_t rdac)** resets one potentiometer to midpoint == 127.
|
|
- **uint8_t readBackRegister()** read register back, for debugging.
|
|
|
|
|
|
#### Experimental
|
|
|
|
- **uint8_t shutDown()** check datasheet, not tested yet, use at own risk.
|
|
|
|
|
|
## Interface AD5421 specific
|
|
|
|
Since 0.4.1 the library supports writing explicit to port 0
|
|
as that is the only port.
|
|
|
|
- **uint8_t write(const uint8_t value)** set rdac 0 to value 0..255.
|
|
- **uint8_t write(const uint8_t value, const uint8_t O1, const uint8_t O2)**
|
|
idem + set output lines O1 and O2 too.
|
|
|
|
|
|
## Operation
|
|
|
|
The examples show the basic working of the functions.
|
|
|
|
|
|
## Error codes
|
|
|
|
| define | value |
|
|
|:---------------|:-------:|
|
|
| AD524X_OK | 0 |
|
|
| AD524X_ERROR | 100 |
|
|
|
|
|
|
## Future
|
|
|
|
#### Must
|
|
|
|
|
|
#### Should
|
|
|
|
- improve error handling.
|
|
- sync with AD520X library
|
|
|
|
#### Could
|
|
|
|
- investigate AD5243 compatibility (or separate library?)
|
|
- has no O1 and O2 lines.
|
|
|
|
|
|
#### Wont
|
|
|
|
- make midpoint 128
|
|
|
|
|
|
## 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,
|
|
|