ledcat
======
[](https://travis-ci.org/polyfloyd/ledcat)
[](https://crates.io/crates/ledcat)
Ledcat is simple utility that aims to provide a standard interface for driving
LED-strips and such.
Simply create a program that outputs 3 bytes of RGB for each pixel in your strip.
## Documentation
* [Transposition and display geometry](doc/transposition.md)
## Usage Examples
```sh
# Make a strip of 30 apa102 leds all red.
perl -e 'print "\xff\x00\x00" x 30' | ledcat --geometry 30 apa102 > /dev/spidev0.0
```
```sh
# Receive frames over UDP.
```sh
# Load an image named "image.png", resize it to fit the size of the display and
# send it to a ledstrip zigzagged over the Y-axis.
```
```sh
# A clock on a zigzagged two dimensional display of 75x8 pixels
while true; do
convert -background black -fill cyan -font Courier -pointsize 8 \
-size 75x8 -gravity center -depth 8 caption:"$(date +%T)" RGB:-
sleep 1;
```sh
# Show random noise as ambient lighting or priority messages if there are any.
mkfifo /tmp/ambient
mkfifo /tmp/messages
cat /dev/urandom > /tmp/ambient &
./my_messages > /tmp/messages &
ledcat --input /tmp/ambient /tmp/messages --linger --geometry 30 apa102 > /dev/spidev0.0
```
### Supported Drivers:
* Linux [spidev](https://www.kernel.org/doc/Documentation/spi/spidev)
* Serial
* Artnet DMX
### Supported Device Types:
* apa102
* [HexWS2811](https://github.com/brainsmoke/hex2811-penta)
* lpd8806
* [hub75](doc/hub75.md)
* ws2812