Python RGB Matrix games and animations https://www.xythobuz.de/ledmatrix_v2.html
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Thomas Buck db0ea2dbea image test runner shows both bilinear and nearest neighbour. add aphex twin logo. před 9 měsíci
fonts more fonts. more instructions. added images and colors from cccamp23 style guide. text rendering now possible with colors. custom font spacing. images automatically scaled and cropped. fixed qr text and colors. allow exiting test gui with q or esc. better target check. před 11 měsíci
hardware various adjustments před 10 měsíci
images image test runner shows both bilinear and nearest neighbour. add aphex twin logo. před 9 měsíci
tools systemd unit před 9 měsíci
.gitignore initial weather page and other small stuff před 9 měsíci
README.md systemd unit před 9 měsíci
bdf.py split text drawing interface into multiple methods. před 10 měsíci
breakout.py tweaks, started work on new game před 9 měsíci
camp_pico.py various adjustments před 10 měsíci
camp_small.py rename images před 9 měsíci
config.py initial weather page and other small stuff před 9 měsíci
copy.sh various on-camp adjustments před 9 měsíci
gamepad.py change brightness with controller. tweak tetris. před 11 měsíci
games.py various on-camp adjustments před 9 měsíci
image.py image test runner shows both bilinear and nearest neighbour. add aphex twin logo. před 9 měsíci
img_tmp.py pre-created images with less whitespace před 10 měsíci
life.py change brightness with controller. tweak tetris. před 11 měsíci
livingroom.py image test runner shows both bilinear and nearest neighbour. add aphex twin logo. před 9 měsíci
manager.py randomized manager should not show same screen twice před 9 měsíci
mapper.py reduce brightness even more at night před 9 měsíci
net.py various on-camp adjustments před 9 měsíci
pi.py various adjustments před 10 měsíci
pi.sh convenience pi update script před 9 měsíci
pico.py Add PicoInput to get buttons on Interstate75 W. před 10 měsíci
pico_ota.py various on-camp adjustments před 9 měsíci
qr.py initial weather page and other small stuff před 9 měsíci
qr_tmp.py pre-created images with less whitespace před 10 měsíci
runner.py tweaks, started work on new game před 9 měsíci
scroll.py kind of fix manager před 10 měsíci
snake.py scale snake to single panel dot count před 9 měsíci
solid.py change brightness with controller. tweak tetris. před 11 měsíci
splash.py change brightness with controller. tweak tetris. před 11 měsíci
telegram.py initial weather page and other small stuff před 9 měsíci
test.py initial weather page and other small stuff před 9 měsíci
tetris.py tetris static piece colors by default před 9 měsíci
util.py randomized manager should not show same screen twice před 9 měsíci
weather.py show missing graphics in weather před 9 měsíci

README.md

RGB Matrix Visualizer

Render various content to various output devices.

Quick Start

Just run:

./manager.py

and go from there.

Dependencies

You always need:

pip install Pillow bdfparser "qrcode[pil]" evdev wetterdienst

For evdev to find all devices you may need to add your user to the input group or run the scripts as root.

The rest depends on the output device chosen. For debugging on your host PC you can use the TestGUI interface with pygame:

pip install pygame

Setup

The other currently supported option is using a Raspberry Pi with the Adafruit RGB Matrix Bonnet and a matching LED Matrix. The tutorial suggests using the Adafruit Raspberry Pi Installer Script for the RGB matrix. This will give you the hzeller/rpi-rgb-led-matrix project which includes the Python bindings used in this project.

Use the included systemd unit to auto-start the script on Raspberry Pi:

sudo cp tools/led.service /etc/systemd/system/led.service
sudo systemctl daemon-reload
sudo systemctl enable --now led.service

Adding your own visualizations

Take a look how others are implemented. You can chain the different screens together using Manager and also check for conditions, as seen in CheckHTTP. This should enable you to quickly create something usable.

One goal is to run this project on public events. If this is the case, and you want your own message to appear, simply open up a PR or send an email with a patch. Because of different versions between host PCs and the Raspbian OS, things may look slightly different, especially regarding stuff like animated GIF viewing.

Licensing

This project is licensed as beer-ware:

----------------------------------------------------------------------------
"THE BEER-WARE LICENSE" (Revision 42):
<xythobuz@xythobuz.de> wrote this file.  As long as you retain this notice
you can do whatever you want with this stuff. If we meet some day, and you
think this stuff is worth it, you can buy me a beer in return.   Thomas Buck
----------------------------------------------------------------------------

The included fonts from farsil/ibmfonts are licensed as CC-BY-SA-4.0.

The fonts from cmvnd/fonts are licensed as GPLv3.

The tiny font is from robey and licensed as CC0.

The included GIFs are from GifCities.

The included DWD weather API documentation is from their website.