2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
[![Arduino CI](https://github.com/RobTillaart/I2CKeyPad/workflows/Arduino%20CI/badge.svg)](https://github.com/marketplace/actions/arduino_ci)
|
2021-11-08 13:13:29 +01:00
|
|
|
[![Arduino-lint](https://github.com/RobTillaart/I2CKeyPad/actions/workflows/arduino-lint.yml/badge.svg)](https://github.com/RobTillaart/I2CKeyPad/actions/workflows/arduino-lint.yml)
|
|
|
|
[![JSON check](https://github.com/RobTillaart/I2CKeyPad/actions/workflows/jsoncheck.yml/badge.svg)](https://github.com/RobTillaart/I2CKeyPad/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/I2CKeyPad/blob/master/LICENSE)
|
|
|
|
[![GitHub release](https://img.shields.io/github/release/RobTillaart/I2CKeyPad.svg?maxAge=3600)](https://github.com/RobTillaart/I2CKeyPad/releases)
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
# I2CKeyPad
|
|
|
|
|
2021-12-19 20:23:20 +01:00
|
|
|
Arduino library for 4x4 KeyPad connected to an I2C PCF8574.
|
2021-11-08 13:13:29 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Description
|
|
|
|
|
|
|
|
The I2CKeyPad library implements the reading of a 4x4 keypad by means of a PCF8574.
|
|
|
|
Smaller keypads, meaning less columns or rows (4x3) can be read with it too.
|
2022-09-29 16:17:30 +02:00
|
|
|
|
|
|
|
Since 0.3.2 the library allows a 5x3, 6x2 or 8x1 or smaller keypad to be connected too.
|
|
|
|
|
|
|
|
Relates to https://github.com/RobTillaart/I2CKeyPad8x8. which is an 8x8 version using PCF8575.
|
2021-11-08 13:13:29 +01:00
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
## Connection
|
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
The PCF8574 is connected between the processor and the (default) 4x4 keypad.
|
|
|
|
See the conceptual schema below.
|
|
|
|
It might take some trying to get the correct pins connected.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
```
|
|
|
|
PROC PCF8574 KEYPAD
|
|
|
|
+--------+ +--------+ +--------+
|
|
|
|
| | | 0|----------|R |
|
|
|
|
| SDA |--------| 1|----------|O |
|
|
|
|
| SCL |--------| 2|----------|W |
|
|
|
|
| | | 3|----------|S |
|
|
|
|
| | | | | |
|
|
|
|
| | | 4|----------|C |
|
|
|
|
| | | 5|----------|O |
|
|
|
|
| | | 6|----------|L |
|
|
|
|
| | | 7|----------|S |
|
|
|
|
+--------+ +--------+ +--------+
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## Interface
|
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
- **I2CKEYPAD(const uint8_t deviceAddress, TwoWire \*wire = &Wire)**
|
2021-05-08 09:52:18 +02:00
|
|
|
The constructor sets the device address and optionally
|
|
|
|
allows to selects the I2C bus to use.
|
2022-09-29 16:17:30 +02:00
|
|
|
- **bool begin()** The return value shows if the PCF8574 with the given address is connected properly.
|
2021-11-08 13:13:29 +01:00
|
|
|
- **bool begin(uint8_t sda, uint8_t scl)** for ESP32.
|
2021-01-29 12:31:58 +01:00
|
|
|
The return value shows if the PCF8574 with the given address is connected properly.
|
2022-09-29 16:17:30 +02:00
|
|
|
- **bool isConnected()** returns false if the PCF8574 cannot be connected to.
|
|
|
|
- **uint8_t getKey()** Returns default 0..15 for regular keys,
|
|
|
|
Returns 16 if no key is pressed and 17 in case of an error.
|
|
|
|
- **uint8_t getLastKey()** Returns the last **valid** key pressed 0..15. Initially it will return 16 (noKey).
|
|
|
|
- **bool isPressed()** Returns true if one or more keys of the keyPad is pressed,
|
2021-11-08 13:13:29 +01:00
|
|
|
however it is not checked if multiple keys are pressed.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
#### Mode functions
|
|
|
|
|
|
|
|
Note: experimental
|
|
|
|
|
|
|
|
- **void setKeyPadMode(uint8_t mode = I2C_KEYPAD_4x4)** sets the mode, default 4x4.
|
|
|
|
This mode can also be used for 4x3 or 4x2.
|
|
|
|
Invalid values are mapped to 4x4.
|
|
|
|
- **uint8_t getKeyPadMode()** returns the current mode.
|
|
|
|
|
|
|
|
**Supported modi**
|
|
|
|
|
|
|
|
There are 4 modi supported, and every mode also supports smaller keypads.
|
|
|
|
E.g. a 4x3 keypad can be read in mode 4x4 or in mode 5x3.
|
|
|
|
|
|
|
|
| modi | value | definition | notes |
|
|
|
|
|:------:|:-------:|:-----------------|:----------|
|
|
|
|
| 4x4 | 44 | I2C_KEYPAD_4x4 | default |
|
|
|
|
| 5x3 | 53 | I2C_KEYPAD_5x3 |
|
|
|
|
| 6x2 | 62 | I2C_KEYPAD_6x2 |
|
|
|
|
| 8x1 | 81 | I2C_KEYPAD_8x1 | not real matrix, connect pins to switch to GND.
|
|
|
|
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
#### KeyMap functions
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
**loadKeyMap()** must be called before **getChar()** and **getLastChar()**!
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
- **char getChar()** returns the char corresponding to mapped key pressed.
|
|
|
|
- **char getLastChar()** returns the last char pressed.
|
|
|
|
- **bool loadKeyMap(char \* keyMap)** keyMap should point to a (global) char array of length 19.
|
|
|
|
This array maps index 0..15 on a char and index \[16\] maps to **I2CKEYPAD_NOKEY** (typical 'N')
|
|
|
|
and index \[17\] maps **I2CKEYPAD_FAIL** (typical 'F'). index 18 is the null char.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
**WARNING**
|
|
|
|
If there is no key map loaded the user should **NOT** call **getChar()** or
|
|
|
|
**getLastChar()** as these would return meaningless bytes.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
```cpp
|
|
|
|
char normal_keymap[19] = "123A456B789C*0#DNF"; // typical normal key map (phone layout)
|
|
|
|
char repeat_keymap[19] = "1234123412341234NF"; // effectively 4 identical columns
|
|
|
|
char partial_keymap[19] = "1234 NF"; // top row
|
|
|
|
char diag_keymap[19] = "1 2 3 4NF"; // diagonal keys only
|
|
|
|
```
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
In the examples above a 'space' key might be just meant to ignore.
|
|
|
|
However functionality there is no limit how one wants to use the key mapping.
|
2022-09-29 16:17:30 +02:00
|
|
|
It is even possible to change the mapping runtime after each key.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
Note: a keyMap char array may be longer than 18 characters, but only the first 18 are used.
|
|
|
|
The length is **NOT** checked upon loading.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
Note: The 5x3, 6x2 and the 8x1 modi also uses a keymap of length 18.
|
|
|
|
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
#### Basic working
|
2021-05-08 09:52:18 +02:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
After the **keypad.begin()** the sketch calls the **keyPad.getKey()** to read values from the keypad.
|
|
|
|
- If no key is pressed **I2CKEYPAD_NOKEY** code (16) is returned.
|
|
|
|
- If the read value is not valid, e.g. two keys pressed, **I2CKEYPAD_FAIL** code (17) is returned.
|
|
|
|
- Otherwise a number 0..15 is returned.
|
2021-05-08 09:52:18 +02:00
|
|
|
|
2022-09-29 16:17:30 +02:00
|
|
|
Note NOKEY and FAIL bot have bit 4 set, all valid keys don't.
|
|
|
|
This allows fast checking for valid keys.
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
Only if a key map is loaded, the user can call **getChar()** and **getLastChar()** to get mapped keys.
|
2021-05-08 09:52:18 +02:00
|
|
|
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
## Interrupts
|
2021-01-29 12:31:58 +01:00
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
Since version 0.2.1 the library enables the PCF8574 to generate interrupts
|
|
|
|
on the PCF8574 when a key is pressed.
|
|
|
|
This makes checking the keypad far more efficient as one does not need to poll over I2C.
|
|
|
|
See examples.
|
2021-01-29 12:31:58 +01:00
|
|
|
|
|
|
|
|
|
|
|
## Operation
|
|
|
|
|
|
|
|
See examples
|
|
|
|
|
2021-11-08 13:13:29 +01:00
|
|
|
|
|
|
|
## Future
|
|
|
|
|
|
|
|
- update documentation
|
|
|
|
- test key mapping functions.
|