Foto: Rebecca Husemann / Make Magazin. Link
Transform a bunch of empty mate crates to a huge display using a 15 year old laptop, a 13US$ microcontroller board and a couple of cheap chinese christmas lights.
Each bottle contains a LED with a WS2801 driver. Each crate contains a chain of 20 LEDs with a 9 pin SUB-D connector. A wiring harness connects 8 crates in series to a TI Stellaris Launchpad. The Launchpad has four hardware SPI interfaces which can control one wiring harness each. The controller board is connected to a ThinkPad T22 running the control program via USB.
Foto: Rebecca Husemann / Make Magazin. Link
Take a mate bottle and wrap it in aluminum foil
Poke a 12mm hole in the lid
Put it in a crate
Repeat from step 1
Stick a loop of LEDs through the lids of the bottles like this:
(seen from back, up↥) ┏━━━━━━━━━━━━━━━━━━━┓ {in}→┃ ○ → ○ → ○ → ○ → ○ ┃ ┃ ↓ ┃ {out}←┃ ○ ○ ← ○ ← ○ ← ○ ┃ ┃ ↑ ↓ ┃ ┃ ○ ○ → ○ → ○ → ○ ┃ ┃ ↑ ↓ ┃ ┃ ○ ← ○ ← ○ ← ○ ← ○ ┃ ┗━━━━━━━━━━━━━━━━━━━┛ (down↧)
Repeat from step 1
Stack up a bunch of these crates and tie them together with zip ties and straps
Connect all the wires together (mis-)using wonderful XLR connectors
???
PROFIT!!
The control software is a Python script accepting framebuffer data via UDP and text via TCP. Since it is run on a 900MHz Pentium 3, the two most time-critical pieces, pixel font rendering for scrolling text and USB communication are written in C and called from the Python script via ctypes.
The server listens on TCP and UDP ports 1337. Any text arriving through TCP is rendered as a marquee, interpreting ANSI escape sequences (colors, blink etc.). The TCP interface accepts one line per connection queuing lines in times of high demand. If there is no more text to render, the system defaults to a list of lines to scroll that is read from the text file default.lines
. When the end of that list has been reached, the file is automatically reloaded enabling run-time configuration.
The UDP port accepts CRAP, our Custom advanced video stReAming Protocol. A CRAP packet contains three bytes of RGB data per pixel in 16 rows of 40 columns (i.e. [R0,0 G0,0 B0,0 R0,1 G0,1 B0,1 ... R0,39 G0,39 B0,39 R1,0 G1,0 B1,0 ... R15,39 G15,39 B15,39]
). A CRC-32 can optionally be added at the end of the packet. A CRAP connection is considered terminated when no packets are received for an interval of by default 3 seconds. CRAP has precedence over text scrolling, any text scrolling when a CRAP connection is initiated is paused and incoming text during a CRAP connection is put into a queue. When multiple CRAP clients are connected, the system by default rotates every 30 seconds to a random new client.
As written before, some parts of these utilities have been factored out into C code. In order to run the utilities requiring these parts (which would otherwise terminate with a python OSError
mentioning some .so
file), you must first build the C backend libraries by running make
inside the host
directory.
The matelight server application lives in server.py
. If you just run this, a matelight server including TCP and UDP/CRAP interfaces is started. The server application supports forwarding the displayed image (including not only incoming CRAP but also scrolled text) via CRAP to the network or localhost. This is configured with crap_fw_addr
and crap_fw_port
in the server config file. If no matelight is connected to your machine, a warning is printed, but the server is left running since this monitoring feature can be used for local testing.
The viewer is a short python script rendering CRAP on your terminal using Unicode and the extended terminal color palette introduced by xterm. This is useful e.g. when diagnosing a running matelight server over the network (through its monitoring port) or when developing CRAP clients. This tool can be run directly with a CRAP client or with the matelight server in between (e.g. if you want to play with marquee rendering, which is done by the matelight server).
If you try this utility and don't see any colors or reduced on your terminal, have a close look at anything supposed to pass through this tool's output to your terminal such as ssh
, cat
and tmux
. Some of these tools will filter/downconvert these extended color sequences depending on the $SHELL
environment variable they encounter.
This utility reads a bunch of CRAP, e.g. from a running matelight server's monitoring port and converts it to a GIF stream (yes, you read that correctly) that is served over a built-in HTTP server (by default running on port 5000). This GIF stream can be viewed with most browsers.
This utility launches a local webserver (by default running on port 5000) presenting an upload form where one may upload a GIF file. An uploaded GIF file is read and streamed to a matelight via CRAP. If a GIF is uploaded while another is already being played, the currently played one is interrupted and replaced by the new one. To prevent a very easy DOS attack, GIF frame durations are capped at 10s.
Spitting out TCP and UDP is pretty much trivial in any programming environment, still there is a bunch of examples below. In case you're using python, you can find one possible CRAP client/server implementation in host/crap.py
.
It would be neat to have a somewhat saner config system using e.g. python's configparser
module with defaults for most things. Also it would be useful to have command line switches to override some of these settings. Pull requests are appreciated!
- "Green Screen" by Hito Steyerl uses a Matelight
- There is one at Temporärhaus in Ulm (archived)
- TUHH STS-FRITZ-Light-Wall used for teaching students game programming
- A Python script that plays gifs over CRAP
- An HTML5 CRAP emulator
- A CRAP client for node.js
- Webcam streaming on Mate Light
- A game programming framework for Mate Light
- Snake for Mate Light
- Game of Life for Mate Light
- Mate Light Android App
- Blinkenlights for Mate Light
- Postillon Newsticker for Matelight
- Movie Streaming and Live 3D Raytracing for Mate-Light in Javascript
- An audio spectrum analyzer
- A Unity 3D backend
- Advanced Conway's Game of Life
- How to CRAP in bash because nc is for noobs
- Noisebridge's ripoff matelight :D
- A Haskell CRAP client library