Arduino Nano - Clavier - LCD

Ce tutoriel vous explique comment utiliser un Arduino Nano pour afficher les entrées d'un clavier sur un écran LCD.

Préparation du matériel

1×Arduino Nano
1×USB A to Mini-B USB cable
1×LCD I2C
1×Keypad 3x4 and 4x4 Kit
1×Breadboard
1×Jumper Wires
1×(Optional) 9V Power Adapter for Arduino Nano
1×(Recommended) Screw Terminal Expansion Board for Arduino Nano
1×(Recommended) Breakout Expansion Board for Arduino Nano
1×(Recommended) Power Splitter For Arduino Nano

Or you can buy the following sensor kits:

1×DIYables Sensor Kit (30 sensors/displays)
1×DIYables Sensor Kit (18 sensors/displays)
Divulgation : Certains des liens fournis dans cette section sont des liens affiliés Amazon. Nous pouvons recevoir une commission pour tout achat effectué via ces liens, sans coût supplémentaire pour vous. Nous vous remercions de votre soutien.

#À propos du clavier et de l'écran LCD

Si vous n'êtes pas familier avec le clavier et l'écran LCD (brochage, fonctionnement, programmation...), les tutoriels suivants peuvent vous aider :

Diagramme de câblage

Schéma de câblage de l'écran LCD du clavier Arduino Nano

This image is created using Fritzing. Click to enlarge image

Code Arduino Nano

/* * Ce code Arduino Nano a été développé par newbiely.fr * Ce code Arduino Nano est mis à disposition du public sans aucune restriction. * Pour des instructions complètes et des schémas de câblage, veuillez visiter: * https://newbiely.fr/tutorials/arduino-nano/arduino-nano-keypad-lcd */ #include <Keypad.h> #include <LiquidCrystal_I2C.h> const int ROW_NUM = 4; //four rows const int COLUMN_NUM = 3; //four columns const byte pin_rows[ROW_NUM] = {10, 9, 8, 7}; // The Arduino Nano pin connected to the row pins of the keypad const byte pin_column[COLUMN_NUM] = {6, 5, 4}; // The Arduino Nano pin connected to the column pins of the keypad char key_layout[ROW_NUM][COLUMN_NUM] = { {'1', '2', '3'}, {'4', '5', '6'}, {'7', '8', '9'}, {'*', '0', '#'} }; Keypad keypad = Keypad( makeKeymap(key_layout), pin_rows, pin_column, ROW_NUM, COLUMN_NUM); LiquidCrystal_I2C lcd(0x27, 16, 2); // I2C address 0x27 (from DIYables LCD), 16 column and 2 rows int cursorColumn = 0; void setup() { lcd.init(); // Initialize the LCD I2C display lcd.backlight(); } void loop() { char key = keypad.getKey(); if (key) { lcd.setCursor(cursorColumn, 0); // move cursor to (cursorColumn, 0) lcd.print(key); // print key at (cursorColumn, 0) cursorColumn++; // move cursor to next position if (cursorColumn == 16) { // if reaching limit, clear LCD lcd.clear(); cursorColumn = 0; } } }

※ Note:

L'adresse du LCD peut varier selon le fabricant. Dans notre code, nous avons utilisé 0x27, comme spécifié par DIYables.

Étapes rapides

  • Connectez un câble USB à l'Arduino Nano et au PC.
  • Ouvrez l’Arduino IDE, sélectionnez la carte et le port appropriés.
  • Cliquez sur l’icône Libraries dans la barre gauche de l’Arduino IDE.
  • Recherchez “keypad” et localisez la bibliothèque de clavier numérique par Mark Stanley et Alexander Brevig.
  • Appuyez sur le bouton Install pour installer la bibliothèque de clavier numérique.
Bibliothèque de clavier pour Arduino Nano
  • Recherchez « LiquidCrystal I2C » et trouvez la bibliothèque LiquidCrystal_I2C créée par Frank de Brabander.
  • Ensuite, cliquez sur le bouton Install pour installer la bibliothèque mentionnée.
Bibliothèque LiquidCrystal I2C pour Arduino Nano
  • Copiez le code et ouvrez-le dans l'IDE Arduino.
  • Cliquez sur le bouton Upload de l'IDE Arduino pour compiler et téléverser le code vers l'Arduino Nano.
Téléversement du code Arduino IDE
  • Appuyez sur certaines touches du clavier
  • Consultez le résultat sur l'affichage LCD

Si l'écran LCD n'affiche rien, consultez Dépannage sur LCD I2C pour obtenir de l'aide.

Explication du code

Consultez l'explication ligne par ligne contenue dans les commentaires du code source !

Vidéo

※ OUR MESSAGES

  • 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!