Hardware
The following components are required for this project:
1. Seeed Studio XIAO ESP32C3
2. NeoPixel Ring - 16 x RGB LED (WS2812B)
3. Three big buttons module
Software
1. Install Arduino IDE 2.0+ for Arduino
2. Install ArduProf lib 1.3+
3. Install Arduino DebugLog lib
4. Install Arduino FastLED lib
5. Clone this github-esp32c3-tiny-game code by "git clone https://github.com/teamprof/github-esp32c3-tiny-game"
Build and run firmware on XIAO ESP32C3
1. Clone this repository by "git clone https://github.com/teamprof/github-esp32c3-tiny-game"
2. Launch Arduino and open the project
3. Wiring XIAO ESP32C3, LED and buttons as below
data:image/s3,"s3://crabby-images/7b951/7b951ba7b81dbc47d716796f632666dcf4bf1b8d" alt=""
4. Build and upload the firmware in Arduino IDE.
If everythong goes smooth, you should see the following in "Monitor"
data:image/s3,"s3://crabby-images/5c26b/5c26b54a5583ed8e92e3852311a8c26a66f94d05" alt=""
Picture of Game stop
data:image/s3,"s3://crabby-images/f66f6/f66f62a859c25ca573de52e42bd5272ad7d978ff" alt=""
5. Click button "Game" to start a new game
data:image/s3,"s3://crabby-images/8d279/8d279e774d244384a5a85b9d50f9f864e3450b27" alt=""
6. Each player clicks its corresponding button. The LEDs labeled ‘Green’ and ‘Blue’ represent player 1 and player 2, respectively.
7. Once a player wins, the LED shows its corresponding color. Picture of Game player1 win
Picture of Game player2 win
data:image/s3,"s3://crabby-images/9c93e/9c93e44f75e662a619036607d838418a25a9ba28" alt=""
LED colors on different state
+------------------+------------+------------------------------+
| LED color | state | status |
+------------------+------------+------------------------------+
| red on (all) | game stop | no winner |
| red blink (all) | game pause | no winner |
| green on (all) | game stop | player1 win |
| green on | game pause | player1 position |
| blue on (all) | game stop | player2 win |
| blue on | game pause | player2 position |
| green/blue blink | game start | player1 and player2 position |
+------------------+------------+------------------------------+
Code explanation in high level
There are two tasks in this project. The first one is "QueueMain" and the second one is "ThreadGame".
"QueueMain" handles hardware events, such as when a player clicks a button, while "ThreadGame" handles game events, such as advancing a player’s position. "RoundLed" is responsible for LEd indication.
Please refer to source code for details
Demo
Video demo is available on [esp32c3-tiny-game]()