100 lines
3.2 KiB
Markdown
Raw Normal View History

2021-01-29 12:31:58 +01:00
[![Arduino CI](https://github.com/RobTillaart/MT8870/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
2021-11-09 21:08:49 +01:00
[![Arduino-lint](https://github.com/RobTillaart/MT8870/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/MT8870/actions/workflows/arduino-lint.yml)
[![JSON check](https://github.com/RobTillaart/MT8870/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/MT8870/actions/workflows/jsoncheck.yml)
2023-11-13 17:37:07 +01:00
[![GitHub issues](https://img.shields.io/github/issues/RobTillaart/MT8870.svg)](https://github.com/RobTillaart/MT8870/issues)
2021-01-29 12:31:58 +01:00
[![License: MIT](https://img.shields.io/badge/license-MIT-green.svg)](https://github.com/RobTillaart/MT8870/blob/master/LICENSE)
[![GitHub release](https://img.shields.io/github/release/RobTillaart/MT8870.svg?maxAge=3600)](https://github.com/RobTillaart/MT8870/releases)
2023-11-13 17:37:07 +01:00
[![PlatformIO Registry](https://badges.registry.platformio.org/packages/robtillaart/library/MT8870.svg)](https://registry.platformio.org/libraries/robtillaart/MT8870)
2021-01-29 12:31:58 +01:00
2021-11-09 21:08:49 +01:00
2021-01-29 12:31:58 +01:00
# MT8870
2021-11-09 21:08:49 +01:00
Arduino library for MT8870 DTMF decoder (breakout).
2021-01-29 12:31:58 +01:00
## Description
This library reads the signals of the MT8870 chip.
If data is available one can read it raw or as text.
2022-11-18 13:36:00 +01:00
DTMF = Dual Tones Multiple Frequency.
These are the tones you hear when you press buttons on your phone.
2021-01-29 12:31:58 +01:00
2022-11-18 13:36:00 +01:00
DTMF tones, uses one from A..D and one from E..H.
2021-11-09 21:08:49 +01:00
2022-11-18 13:36:00 +01:00
| Name | Frequency |
|:------:|------------:|
2023-11-13 17:37:07 +01:00
| A | 697 Hz |
| B | 770 Hz |
| C | 852 Hz |
| D | 941 Hz |
2022-11-18 13:36:00 +01:00
| E | 1209 Hz |
| F | 1336 Hz |
| G | 1477 Hz |
| H | 1633 Hz |
2021-11-09 21:08:49 +01:00
2021-01-29 12:31:58 +01:00
## Interface
2023-11-13 17:37:07 +01:00
```cpp
#include "MT8870.h"
```
2021-01-29 12:31:58 +01:00
- **MT8870()** constructor
2021-11-09 21:08:49 +01:00
- **void begin(uint8_t STQ, uint8_t Q1, uint8_t Q2, uint8_t Q3, uint8_t Q4)** defines which pins to use.
2021-01-29 12:31:58 +01:00
Technically it is possible to have readout multiple decoders
with one MT8870 object by calling **begin()** with other pins.
- **STQ** = data available signal
2021-11-09 21:08:49 +01:00
- **Q1..Q4** = data pins.
2021-01-29 12:31:58 +01:00
- Calling begin resets the **lastRead** char
- **bool available()** returns true if there is a DMTF signal
2023-11-13 17:37:07 +01:00
- **char read()** reads the character available. Returns 255 if no signal available.
2021-01-29 12:31:58 +01:00
- **uint8_t readRaw()** returns 0 .. 15 or 255 if no signal is available.
2021-11-09 21:08:49 +01:00
- **uint8_t lastRaw()** returns the last code read 0 .. 15 or 255 if no signal available.
2021-01-29 12:31:58 +01:00
Note this is a cached value from a readRaw / read call.
2021-11-09 21:08:49 +01:00
- **uint32_t lastTimeRead()** returns the timestamp of last **read()** or **readRaw()**.
2021-01-29 12:31:58 +01:00
2021-12-22 11:05:27 +01:00
## Operations
2021-01-29 12:31:58 +01:00
2021-12-22 11:05:27 +01:00
See examples.
2021-01-29 12:31:58 +01:00
2022-11-18 13:36:00 +01:00
## Future
2021-12-22 11:05:27 +01:00
2023-11-13 17:37:07 +01:00
#### Must
2021-12-22 11:05:27 +01:00
- improve documentation
2022-11-18 13:36:00 +01:00
- keypad matrix, which key generates which tones
2023-11-13 17:37:07 +01:00
#### Should
2021-12-22 11:05:27 +01:00
- test setup
2022-11-18 13:36:00 +01:00
- add examples
2021-12-22 11:05:27 +01:00
- DMTF with a PCF8574
- DMTF as secret key
- DMTF with less keys (less pins)
- DMTF over interrupt triggered by STQ line
2022-11-18 13:36:00 +01:00
2023-11-13 17:37:07 +01:00
#### Could
2022-11-18 13:36:00 +01:00
- buffer like Serial? (how to fill? interrupt? example sketch?)
- read part of stream interface?
2021-12-22 11:05:27 +01:00
- DMTF tone generation?
2022-11-18 13:36:00 +01:00
- MCP_DAC
- PWM + HW?
2021-01-29 12:31:58 +01:00
2023-11-13 17:37:07 +01:00
#### Wont
## 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,