Using Node-RED MCU Part 1 (Node-RED, M5Stack)
Introduction
In this article, I used a Node-RED MCU to write a program on the M5Stack. I had introduced a bit of this in a previous article, but I have been using Node-RED MCU exclusively since Maker Faire Kyoto was finished.
Node-RED MCU is a plugin for Node-RED. It allows you to create programs for microcontrollers in Node-RED.
I wrote the introduction of Node-RED in the book introduction page.
▼Click here for the book introduction.
Please also refer to the book for information on building the environment; it vary depending on your OS. Also, please note that future updates to the Node-RED MCU may change the way you build your environment. This is a technology that is still under development.
▼Previous article is here.
Creating Flows in Node-RED
Display "Hello, World!"
First, I give a short introduction to how to use Node-RED.
In Node-RED, you can program by connecting nodes with lines. Let's create a flow that displays "Hello, World!".
▼When you start Node-RED, it looks like this. Let's use the inject and debug nodes on the left side.
data:image/s3,"s3://crabby-images/3e1d9/3e1d9ecc41eff67ef3c5ed30d9683c300800b6db" alt=""
▼Connect the nodes with lines and press Deploy in the upper right corner to apply the changes.
data:image/s3,"s3://crabby-images/125ff/125ff4f34da631ff82dc7b82c5346cffae17499d" alt=""
▼Press the button to the left of the timestamp to send data to the debug node.
data:image/s3,"s3://crabby-images/62560/62560ef3a2d595ac61798f18a3a558723ad03045" alt=""
▼The contents of the node looks like this: the msg.payload item is the subject of the debug node.
data:image/s3,"s3://crabby-images/b3db1/b3db111483b18c9a64f98216231fc5b6768c5a29" alt=""
data:image/s3,"s3://crabby-images/0444b/0444b9160f6d7d9b1b526b491988c6e0711e58fc" alt=""
▼Let's try changing the msg.payload of the inject node to Hello, World!
data:image/s3,"s3://crabby-images/262ea/262ea16654c5032c2600c6c3431fb51ae25a3bad" alt=""
▼Then “Hello, World!” will appear in the debug window.
data:image/s3,"s3://crabby-images/444ac/444ac294da5366c50fb023ff6531e9222c7faf09" alt=""
Adding nodes to the Node-RED MCU
Let's add a node for the Node-RED MCU.
▼Select Manage Palette from the menu in the upper right corner.
data:image/s3,"s3://crabby-images/d9150/d91508300438e0558a39fe2f795a13878ce8ad7b" alt=""
▼In the Add Node section, search for and add node-red-mcu-plugin.
data:image/s3,"s3://crabby-images/46511/46511184aeaf350e8736cfd15db052951b7b6c32" alt=""
▼When added and lined up, it looks like this. The node for the MCU is added on the left.
data:image/s3,"s3://crabby-images/7189a/7189a77adedcd3a5c349851d61d58a60ad472a86" alt=""
For example, the flow shown in the image above is as follows.
- Send the value acquired by the temperature/humidity sensor of the SHT3x series to the debug node.
- The LEDs connected to pins 26 and 27 are turned on according to the state of the switch on pin 12.
Write programs to M5Stack CORE2
Node-RED MCU is especially compatible with ESP-based microcontrollers, and the one I used this time is the M5Stack CORE2. CORE2 has a touch display.
Using button node
This is a simple sample program introduced in the book. Press the A and B buttons shown on the display, and the text will appear in the display.
▼Only a few nodes are required. It would be much more difficult to write in code.
data:image/s3,"s3://crabby-images/d4ac7/d4ac75b146dda5fbcd638bd79b12850a8edc1c88" alt=""
▼The screen actually looks like this. You can set the placement of buttons by yourself.
data:image/s3,"s3://crabby-images/26468/264682b2f449cf841bdab5f53d4f51973748830c" alt=""
data:image/s3,"s3://crabby-images/7c4bb/7c4bb6400bcd0d67b2ec1791abfa48ea82dea26a" alt=""
Change the color of the full-color LEDs with the buttons
▼I made the nekomimi I received from Maker glow. It uses full-color LEDs with a chip called NeoPixel.
▼The flow is just this: I write a program inside a function node. The flow is easy to understand.
data:image/s3,"s3://crabby-images/ed52b/ed52b29689e95c99fe806a97770aad567dfc3dfc" alt=""
▼Here is the content of the function node, which is JavaScript.
data:image/s3,"s3://crabby-images/5bc6f/5bc6f8e42d06914612544372b37fbe3ab1702b19" alt=""
▼Here is the screen for editing the dashboard layout. It is easy to edit.
data:image/s3,"s3://crabby-images/0edeb/0edeb3a1536482e1324386cf1a88ace727b96ac9" alt=""
Finally
I usually write programs in code, so visual programming like Node-RED seems so much easier. I have only tested a few simple operations, but I think I can do a lot of things with Node-RED. It is possible to display sensor values in a graph.
I'd like to combine it with web-based technologies to create something like IoT. I will try various things.