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,
|
|
|
|
|