pi-led
pi-led
A simple helper program to control LEDs attached to one or multiple GPIO pins of a Raspberry Pi. It supports single- or multichannel (RGB) LEDs via the use of a simple configuration file.
Installation
There are two basic ways to install pi-led
: Build it directly on the Raspberry Pi, or via cross-compilation.
The first way is more convenient if you just wish to use pi-led
; if you plan on forking your own version, the second way may be a better choice because it will likely lead to shorter compilation times and enables you to use the development environment on your desktop PC.
In either case you will need the Crystal compiler installed on the RPi, which is nothing of a problem anymore: E.g., on Raspbian/Raspberry Pi OS, just enter
sudo apt install crystal
into a terminal and you're done.
Method 1: Build directly on the Raspberry Pi
Clone the GitHub repository to a folder on the Raspberry Pi. cd
into that folder and run shards build
. That's it! The program should now be available in the bin
subfolder and can be copied/linked to however you see fit.
Method 2: Cross-compile
Clone the GitHub repository to a folder on your desktop PC. Under the assumptions that ...
- you are working on Raspbian/Raspberry Pi OS,
- left the default user and host name on the RPi unchanged (
pi@raspberrypi
), - can connect to the Raspberry Pi via SSH using a non-interactive authentication method like public key or SSL certificate,
... you may be able to follow the exact same build procedure that works for me, which I have automated with a Makefile: First, turn on your Pi (headless is completely sufficient). Then, on your desktop PC, cd
into your local clone of the repo, and enter make cross-pi
or simply make
. This will attempt to
- invoke the Crystal compiler once on your desktop machine with the
--cross-compile
option set, - transfer the resulting object file and linkage information to the Pi via SFTP, and
- link everything together on the Pi by issuing a remote command via SSH.
It is, however, not unlikely that things don't work out for you that simple. In this case, check that the above conditions are all met in your setting, and try to adjust the values in the Makefile accordingly. If it still doesn't work, you may have to reproduce the make procedure step by step - or revert to method 1 outlined above.
Configuration
To inform pi-led
about your LEDs and the GPIO pins they are connected to, you must provide it with a simple configuration file. By default, pi-led
attempts to read the file ~/.pi-led.ini
. This path can be overridden with the -c
command line option.
The config file is an INI-style list of sections, where
- each section title must be a unique name that distinguishes some particular LED (LED identifier);
- in each key-value pair, the key must consist of a single letter that serves as a channel identifier; and
- the value denotes the GPIO pin number this channel is connected at, in the range 0..27. Example of a configuration file for a 2 LEDs setup:
[MyFirstLED]
W=15
[Colored]
R=2
G=3
B=4
Patterns
Channel and LED identifiers can then be used together with pausing information to create arbitrary blinking patterns that your LEDs will repeat until another pattern is put into effect. Patterns are composed from tokens separated by whitespace, where each token must be one of the following:
- An LED identifier that matches exactly the name of the corresponding section in the config file and is followed by a colon as in
MyFirstLED:
. This will affect all subsequent tokens until another LED identifier is encountered. As long as no LED identifier is present,pi-led
will interpret all channels as referring to the first LED section in the config file. - A combination of uppercase and lowercase versions of channel identifiers: An uppercase letter leads to the channel being turned on (i.e., the corresponding GPIO pin will be set to "high" voltage), while lowercase letters turn it off again.
- A pause command, consisting of an integer and an optional unit string that together denote a time span to wait before the next token is executed. Valid unit strings are
h
,min
,s
,ms
,µs
, andns
. If no unit string is specified, "ms" (milliseconds) is assumed as default. - A single hyphen character (
-
), which serves as a shortcut to switch off all channels of the currently selected LED. (Thus, if the LED has three channelsa
,b
, andc
,-
would be equivalent toabc
.)
Usage
Once pi-led
runs, patterns can be started by simply providing them on STDIN as a line of input. The pattern will be stay in effect until it is replaced by another one. Thus patterns can also be easily switched by scripts or other programs that rely on pi-led
as a child process, via piping.
Contributing
- Fork it (https://github.com/mastoryberlin/pi-led/fork)
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Add some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create a new Pull Request
Contributors
- Mastory Berlin - creator and maintainer
pi-led
- 0
- 0
- 0
- 0
- 0
- over 4 years ago
- August 26, 2020
MIT License
Tue, 21 Jan 2025 11:18:08 GMT