Arduino MicroPython Keypad 3x4

This guide shows you how to use an Arduino with a 3x4 keypad and MicroPython. You will learn:

Arduino MicroPython 3x4 Keypad

Hardware Preparation

1×Arduino Giga R1 WiFi
1×USB Cable Type-C
1×Membrane Keypad 3x4
1×Jumper Wires
1×(Recommended) Screw Terminal Block Shield for Arduino Uno/Mega/Giga
1×(Recommended) Breadboard Shield For Arduino Mega/Giga
1×(Recommended) Enclosure For Arduino Giga
1×(Recommended) Power Splitter For Arduino Giga

Or you can buy the following sensor kits:

1×DIYables Sensor Kit (30 sensors/displays)
1×DIYables Sensor Kit (18 sensors/displays)
Disclosure: Some of the links provided in this section are Amazon affiliate links. We may receive a commission for any purchases made through these links at no additional cost to you.
Additionally, some of these links are for products from our own brand, DIYables .

Overview of 3x4 Keypad

The 3x4 keypad has 12 soft keys arranged in a grid of rows and columns. Each key represents a button.

Pinout

A 3x4 keypad has 7 pins. These pins are split into two types: rows and columns.

  • 4 pins connect to the rows (R1, R2, R3, R4).
  • 3 pins connect to the columns (C1, C2, C3).
3x4 Keypad Pinout

Wiring Diagram

The wiring diagram between Arduino MicroPython Keypad 3x4

This image is created using Fritzing. Click to enlarge image

Arduino MicroPython Code

from DIYables_MicroPython_Keypad import Keypad import time NUM_ROWS = 4 NUM_COLS = 3 # Constants for GPIO pins ROW_PINS = ['D14', 'D15', 'D16', 'D17'] # The Arduino Giga WiFi pins connected to the row pins COLUMN_PINS = ['D18', 'D19', 'D20'] # The Arduino Giga WiFi pins connected to the column pins # Keymap corresponds to the layout of the keypad 3x4 KEYMAP = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'] # Initialize the keypad keypad = Keypad(KEYMAP, ROW_PINS, COLUMN_PINS, NUM_ROWS, NUM_COLS) keypad.set_debounce_time(400) # 400ms, addjust it if it detects twice for single press print("Arduino MicroPython - Keypad 3x4 example") # Main loop to check for key presses while True: key = keypad.get_key() if key: print("Key pressed: ", key)

Detailed Instructions

Here’s instructions on how to run the above MicroPython code on Arduino with Thonny IDE:

  • Make sure Thonny IDE is installed on your computer.
  • Make sure MicroPython firmware is installed on your Arduino board.
  • If you are new to Arduino with MicroPython, see the Getting Started with Arduino and MicroPython.
  • Connect your Arduino to the 3x4 keypad as shown in the diagram.
  • Connect the Arduino board to your computer with a USB cable.
  • Open Thonny IDE and go to Tools Options.
  • Under the Interpreter tab, select MicroPython (generic) from the dropdown menu.
  • Select the COM port corresponding to your Arduino board (e.g., COM33 on Windows or /dev/ttyACM0 on Linux).
  • Navigate to the Tools Manage packages on the Thonny IDE.
  • Search “DIYables-MicroPython-Keypad”, then find the Keypad library created by DIYables.
  • Click on DIYables-MicroPython-Keypad, then click Install button to install Keypad library.
Arduino MicroPython Keypad library
  • Copy the provided Arduino MicroPython code and paste it into Thonny's editor.
  • Save the MicroPython code to your Arduino by:
    • Clicking the Save button or pressing Ctrl+S.
    • In the save dialog, choose MicroPython device and name the file main.py.
  • Click the green Run button (or press F5) to execute the code.
  • Press a few keys on your keypad.
  • Check out the message in the Shell at the bottom of Thonny.
Shell x
>>> %Run -c $EDITOR_CONTENT
MPY: soft reboot MPY: soft reboot Arduino MicroPython - Keypad 4x4 example Key pressed: 1 Key pressed: 2 Key pressed: 3 Key pressed: 6 Key pressed: 9 Key pressed: 4 Key pressed: * Key pressed: #
MicroPython (generic) • Giga Virtual Comm Port in FS Mode @ COM33 ≡

If it does not work, please check your wiring carefully. It is very easy to confise when connecting Arduino to the keypad 3x4.

Keypad and Password

A keypad is often used to type in a password. Here, we focus on two important keys:

  • A key to start or restart typing the password. For example, use the key "*."
  • A key to finish typing the customer. For instance, use the key "#."

The password will consist of the other keys, except for two special keys that are not included.

When you press a key.

  • If the key is neither "*" nor "#", include it in the password being typed.
  • If the key is "#", verify if the typed password is correct, then clear it.
  • If the key is "*", clear the password.

Keypad - Password Code

""" This Arduino MicroPython script was developed by newbiely.com This Arduino MicroPython script is made available for public use without any restriction For comprehensive instructions and wiring diagrams, please visit: https://newbiely.com/tutorials/arduino-micropython/arduino-micropython-keypad-3x4 """ from DIYables_MicroPython_Keypad import Keypad import time NUM_ROWS = 4 NUM_COLS = 3 # Constants for GPIO pins ROW_PINS = ['D14', 'D15', 'D16', 'D17'] # The Arduino Giga WiFi pins connected to the row pins COLUMN_PINS = ['D18', 'D19', 'D20'] # The Arduino Giga WiFi pins connected to the column pins # Keymap corresponds to the layout of the keypad 3x4 KEYMAP = ['1', '2', '3', '4', '5', '6', '7', '8', '9', '*', '0', '#'] # Initialize the keypad keypad = Keypad(KEYMAP, ROW_PINS, COLUMN_PINS, NUM_ROWS, NUM_COLS) keypad.set_debounce_time(400) # 400ms, addjust it if it detects twice for single press # Define the correct password correct_password = "1234" input_password = "" print("Arduino MicroPython - Keypad 3x4 password") # Main loop while True: key = keypad.get_key() if key: print(key) if key == '*': input_password = "" # Clear input password elif key == '#': if input_password == correct_password: print("Password is correct") # DO YOUR WORK HERE else: print("Password is incorrect, try again") input_password = "" # Clear input password else: input_password += key # Append new character to input password string
  • Copy the above code and paste it to the Thonny IDE's editor.
  • Save the script to your Arduino
  • Type in "123", follow with pressing “#.”
  • Type in "1234", then press "#."
  • Check out the message in the Shell at the bottom of Thonny.
Shell x
>>> %Run -c $EDITOR_CONTENT
MPY: soft reboot MPY: soft reboot Arduino MicroPython - Keypad 3x4 password 1 2 3 # Password is incorrect, try again 1 2 3 4 # Password is correct
MicroPython (generic) • Giga Virtual Comm Port in FS Mode @ COM33 ≡

Video Tutorial

※ OUR MESSAGES

  • As freelancers, We are AVAILABLE for HIRE. See how to outsource your project to us
  • Please feel free to share the link of this tutorial. However, Please do not use our content on any other websites. We invested a lot of effort and time to create the content, please respect our work!