Local serial connection sequence:
- Power the tree with 5V external power
- Connect to the MCU via USB
- Install PlatformIO
- Install clang-format
- Copy
src/wifi_config.h.sample
tosrc/wifi_config.h
and fill in the appropriate values. - Copy
src/ota_config.h.sample
tosrc/ota_config.h
and fill in the appropriate values.
local
- for connecting locally via serialota
- for Over The Air uploads- Currently needs
upload_port
andupload_flags
to be set inplatformio.ini
- Currently needs
pio run -e [env name]
pio run -e [env name] -t upload
Commands are received on the MCU via UDP packets. Each packet starts with a 1-byte identifier followed by zero or more bytes specific to that command.
UDP_BUFFER_SIZE
is the max buffer size to read from a UDP packet. It should be large enough to support the largest command, i.e. a command to uniquely set all pixels to a color would need (PIXEL_COUNT * 3) + 1 bytes. 1 byte for the command, and three 8-bit channels for each pixel.
command | minimum data | maximum data |
---|---|---|
1 byte | 0 bytes | (UDP_BUFFER_SIZE - 1) bytes |
- Each parameter is required.
- Each parameter is a byte unless otherwise noted.
- For values that are larger than 1 byte, we use big-endian.
- Parameter table rows correspond to data byte indices (row 0 is byte 0).
Turns off the LEDs.
Command |
---|
0 |
Sets the brightness of the LEDs.
Command | Level |
---|---|
1 |
0 - 255 |
Sets the color of a single pixel.
Command | Offset | Red | Green | Blue |
---|---|---|---|---|
2 |
0 - (PIXEL_COUNT-1) |
0 - 255 |
0 - 255 |
0 - 255 |
Fills all LEDs with a single color.
Command | Red | Green | Blue |
---|---|---|---|
3 |
0 - 255 |
0 - 255 |
0 - 255 |
Fills the tree by repeating the colors provided.
Command | Number of colors provided | Red | Green | Blue |
---|---|---|---|---|
4 |
0 - 255 |
0 - 255 |
0 - 255 |
0 - 255 |
Red, green, and blue parameters can be repeated up to PIXEL_COUNT
times.
Animates the tree with a colorful rainbow effect. Repeatable.
Command | Repeat |
---|---|
5 |
0 - 1 |
Like Rainbow, but colors are equally distributed. Repeatable.
Command | Repeat |
---|---|
6 |
0 - 1 |
Shows theater-style crawling lights with provided color. Repeatable.
Command | Number of colors provided | Red | Green | Blue |
---|---|---|---|---|
7 |
0 - 255 |
0 - 255 |
0 - 255 |
0 - 255 |
A special command used by clients to get the currently running sequence on the tree.
Command |
---|
255 |
This command takes no parameters. The data received shouldn't be larger than UDP_BUFFER_SIZE
.
Important note: Currently it's the responsibility of the reciever to know what bytes are valid, depending on the command. For instance:
- The Pattern Fill command is sent with 10 colors (at least 30 bytes)
- The Rainbow command is sent.
- The Readback command is sent.
Because the Readback command sends the raw packet buffer and doesn't factor in the total length of the Rainbow command, it'll contain the previous values from setup 1. The client should know (based on byte 0) that the tree is running the Rainbow command and to only read the valid bytes.
If the Pattern Fill command is being read, pay attention to the byte with the number of colors to know how many subsequent bytes to expect.