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)
|
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)
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
DTMF = Dual Tones Multiple Frequency, it are the tones you
|
|
|
|
hear when you press buttons on your phone.
|
|
|
|
|
2021-11-09 21:08:49 +01:00
|
|
|
DTMF tones, uses one from A..D one from E..H.
|
|
|
|
|
|
|
|
| Name | Frequency |
|
|
|
|
|:----:|----------:|
|
|
|
|
| A | 697 Hz |
|
|
|
|
| B | 770 Hz |
|
|
|
|
| C | 852 Hz |
|
|
|
|
| D | 941 Hz |
|
|
|
|
| E | 1209 Hz |
|
|
|
|
| F | 1336 Hz |
|
|
|
|
| G | 1477 Hz |
|
|
|
|
| H | 1633 Hz |
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
|
|
|
- **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
|
|
|
|
- **char read()** reads the character available. returns 255 if no signal available.
|
|
|
|
- **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
|
|
|
|
|
|
|
|
|
|
|
## Future / ideas / improvements
|
|
|
|
|
|
|
|
- buffer like Serial? (how to fill? interrupt? example sketch?)
|
|
|
|
- DMTF tone generation?
|
|
|
|
- more examples!
|
|
|
|
|
|
|
|
|
|
|
|
## Operations
|
|
|
|
|
|
|
|
See examples.
|