Pi Frame is a lightweight starter kit for printing timely data or art (or both) to an e-ink/e-Paper display. It’s like your own newspaper, except that it updates itself however often you like and with whatever content you find interesting.
To run Pi Frame you need to first:
- Join a Wi-Fi network on your Raspberry Pi
- Enable SSH on your Raspberry Pi
- Plug in a Waveshare e-Paper or similar display to your Raspberry Pi
Waveshare displays require some additional setup. See the Hardware Connection and Python sections of your model’s manual.
Copy all the contents of this Pi Frame repository over to the main directory of your Raspberry Pi. Or, at a minimum, bring over the lib directory and that of either Date Stamp or Year Progress.
The lib directory includes vendored copies of each Waveshare display driver taken from the official repository. Make sure to add your own display’s driver to lib if you aren’t using a Waveshare display.
Now you just need to tell Pi Frame which display to expect and download any required packages.
Look for this line as the last import in each Pi Frame app:
from waveshare_epd import epd5in83_V2 as display
Swap out the epd5in83_V2
for your Waveshare e-Paper display driver in the lib directory. Non-Waveshare displays should be imported here too, although you’ll need to make display-specific adjustments needed wherever display
is called further on.
See requirements.txt for a short list of packages required for Pi Frame’s built-in demo apps. Only python3-pil
is required as of writing this.
Install each package on your Raspberry Pi using sudo apt-get
. Here’s an example:
sudo apt-get update
sudo apt-get install python3-pil
Run Pi Frame apps just like you would any other Python file on a Raspberry Pi:
# Run the Date Stamp demo app
cd date-stamp
python3 app.py
# Or run the Year Progress demo app
cd year-progress
python3 app.py
Pi Frame is noisy by default. Look for the results in Terminal.
Check out the list of apps below. Just like what’s been mentioned: copy one of them over to your Raspberry Pi’s main directory, replace the driver name in its import, install the required packages, and run.
Here is a list of apps I’ve built to make Pi Frame my own. Read on for how to schedule these apps at certain hours of the day and/or days of the week.
The Pi Frame repository is limited to three basic apps in order to keep its complexity to a minimum. None of these apps require any authentication or setup beyond some minimal package installation, which is covered above.
Name | Description |
---|---|
Date Stamp | Prints today’s date according to the time zone set on your Pi. |
Year Progress | Prints a how far through the year we are. |
Eraser | Wipes the Pi’s screen clean. |
These apps are why Pi Frame exists: they’re all things I wanted to track or see throughout the day. Each of them require an internet connect and package installation. They have optional customisation for your location and preferences.
Name | Description |
---|---|
Where ISS | Prints what the International Space Station sees of Earth. |
Art Press | Prints a random item from the Art Institute of Chicago's collection. |
Surf Grid | Prints the day's surf report in the style of Kōhei Sugiura. |
These are external projects that I think could be nice for Pi Frame.
Name | Description |
---|---|
SlowMovie | A Very Slow Movie Player for Raspberry Pi. |
Pi Frame relies on cron to schedule apps to run at certain hours of the day and/or days of the week. Make sure your Raspberry Pi’s time zone is correct before setting up cron jobs. You can read how to do this in the appendix.
First, give cron permission to use the launcher file for each app:
# Art Press
chmod 755 art-press/launcher.sh
# Year Progress
chmod 755 year-progress/launcher.sh
## And so on...
Repeat this chmod 755
line for each app you’d like to have on a schedule.
Second, set up the actual crontab process. Make sure you include the sudo
in this command:
sudo crontab -e
This will open up the crontab file that needs to be filled out. Refer to the crontab.example file in this repository for a starting point and crontab.guru to create custom schedules. Paste in (or write) your cron jobs in the crontab. Save it out.
Pi Frame’s crontab.example includes instructions for cron to save logs (including errors) to a cronlog.log file at your Raspberry Pi’s main directory. This cronlog.log will be overwritten each time cron runs one of the scheduled jobstasks.
Pi Frame apps get their size and optical offset positions from the layout.py module. I recommend you first set up your display how you like within a picture frame (with a window mat cut from thick paper stock) before adjusting these values.
External apps such as Where ISS, Art Press, and Surf Grid have their layout values hardcoded in the interest of portability. You’ll need to remove these hardcoded values and un-comment the layout.py module import and references in order to use the shared values.
I’d love to hear how you go with this project. Drop any issues as GitHub issues and email me for anything else.
Check out Scott Kildall‘s write-up on cron, scheduling, and Python file launchers on Rasperry Pi. Also check out Michael Klements‘ tutorial on Waveshare displays, APIs, and Raspberry Pi.
Waveshare recommends you update the display’s contents at least once every 24 hours to prevent burn-in. I don’t keep anything longer than 12 hours to be safe. I also schedule the Eraser app every night between sleeping hours.
I recommend you use your local time zone for scheduling apps. You can do this with a simple command on your Raspberry Pi:
date
Here’s how to edit your time zone if it isn’t accurate:
sudo raspi-config
Navigate down to Localisation Options and then Timezone to find yours. UTC is tucked away under None of the above.
I like using Transmit to transfer files to and from the Pi. You could also use scp
. Here are some basic commands:
Upload a whole directory with scp
Useful for installing Pi Frame apps.
# Uploading the `app-name` directory to your Pi at an IP address
scp -r app-name/ [email protected]:
# Uploading the `app-name` directory to your Pi at its hostname
scp -r app-name/ pi@raspberrypi:
The rest of these instructions will assume you are using the pi@raspberrypi
hostname.
Upload a single file with scp
Useful for uploading Pi Frame app edits.
# Copy a file from the `app-name` directory from your computer to your Pi
scp app-name/app.py pi@raspberrypi:app-name/app.py
Delete a whole directory via scp
# Danger!
# This irreversibly deletes the entire folder and its contents
sudo rm -rf app-name
I find it doesn’t have enough oompf to make anything practical. Let me know if you find otherwise.