Skip to main content

Utilities for the LED display on the Raspberry Pi Sense HAT

Project description

# Raspberry Pi Sense HAT display utility library

Fun toys for the Sense HAT LED display. Works well with Home Assistant.

This code is not yet ready for public consumption, but it shouldn't do any damage.

## Currently implemented

### `print`

Print some text set with `--message` on the tiny 8x8 pixel display.

Not much good on its own, but is called by the next command.

### `scroll`

A classic scrolling text effect. Reads from stdin by default. Use the `--message` option to pass text from the command-line instead.

The default font has lots of accented characters, but you can use a different font with the `--font` option.
Both .ttf and .pil fonts are supported.

If you use a TrueType font then you might need to play with the `--font_size` option to make it readable.

Invert the display with `--invert true` or set foreground and background colours with `-c` and `-bg`. These can be named or "#rrggbb" hex colours.

Use `--repeat -1` to scroll forever.
Use `--autorestore true` to restore whatever was on the screen before when done scrolling.

### `pulse`

Pulse a colour (`-c`) out and in. Best used with the `--speed` and `--repeat` options.

### `show_clock`

Show a tiny analogue clock.

Use `--repeat -1` to use your Sense HAT as an inaccurate timekeeper.

### `fade_out`

Fade to black. Or, rather, fade to 47, which is the same thing.

### `show_icon`

Icons coming soon.


## Getting started

You'll need a Raspberry Pi and Sense HAT first.

### Prerequisites

Change to the directory you downloaded this to.

Install requirements:
```
pip install -r requirements.txt
```

### Running

Make sure it's all working:
```
python main.py scroll --message "Hello from the Raspberry Pi Sense HAT utility library!"
```

You should see the message scroll across your Sense HAT LEDs.

If it's upside down, then use the `--rotation` option (it's set to 180 by default).

## Using with Home Assistant

This works rather nicely combined with Home Assistant's notify module using its command-line platform.

### Prerequisites

Prepare Home Assistant:

* Add a new line to the end of `configuration.yaml`:
```
echo 'notify: !include notify.yaml' >> configuration.yaml
```

* Create `notify.yaml` and set up various notification entities:
```
- name: good
platform: command_line
command: /srv/homeassistant/bin/python /home/homeassistant/SenseHatUtilities/main.py -c green scroll
- name: bad
platform: command_line
command: /srv/homeassistant/bin/python /home/homeassistant/SenseHatUtilities/main.py -c red scroll
- name: warning
platform: command_line
command: /srv/homeassistant/bin/python /home/homeassistant/SenseHatUtilities/main.py -c yellow scroll
- name: info
platform: command_line
command: /srv/homeassistant/bin/python /home/homeassistant/SenseHatUtilities/main.py -c cyan scroll
```

* Restart Home Assistant

### Test it

* Go to Services, under Developer Tools
* Select the `notify.good` service
* In the Service Data field, enter `{"message":"Home Assistant is talking to you via SenseHatUtilities!"}`
* Click the Call Service button and watch your Sense HAT.

### Use it in your automations

* Send the current temperature

### Go further

You can chain calls easily with a shell script.

Make sure important messages aren't missed: try using the `pulse` action to flash the LEDs a few times before using `scroll_repeat` to repeat the message a few times.


## Acknowledgements

* Pi and Sense HAT creators
* Home Assistant creators
* Miniwi font creator

[Docs](http://sense-hat-display-utilities.readthedocs.io/en/latest/)


Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

sense_hat_display_utils-0.1.6.tar.gz (10.4 kB view details)

Uploaded Source

Built Distribution

sense_hat_display_utils-0.1.6-py2.py3-none-any.whl (14.5 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file sense_hat_display_utils-0.1.6.tar.gz.

File metadata

File hashes

Hashes for sense_hat_display_utils-0.1.6.tar.gz
Algorithm Hash digest
SHA256 fefba0c5004d676a02d7874b6378c769dcde3c661e2030a4ea656e19472c9855
MD5 ab2510414858f786590e1242a60d97de
BLAKE2b-256 2d9a1a42c7c1173172f0f5f334b1e0ba93ae340b44103b8f52c663f7f2658c38

See more details on using hashes here.

File details

Details for the file sense_hat_display_utils-0.1.6-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for sense_hat_display_utils-0.1.6-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 13c38f12413c2d9c8683bae08d54641868cb2dc0e396dfeadb29fbece1b40d39
MD5 add660aad158fbc8b11e5523840ea73a
BLAKE2b-256 05397c09005f4ed12688f5cf1ebba11706c3e451934fc1a1f619a7327daa360d

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page