/rmv-rpi-display

RMV Departures Raspberry Pi Display

Primary LanguagePythonMIT LicenseMIT

RMV Timetable Viewer

This is a small piece of software allowing bus and tram departures for some station to be shown on a small e-ink display.

It is specific for the RMV, the Rhein-Main-Verkehrsverbund, a regional Hessian public transport provider. It interfaces with their open data portal, but should work with most HAFAS APIs with only minor modifications.

Hardware

It uses an (overkill) Raspeberry Pi 3, as the case was already designed for that. The case can be 3D printed from the files given in 3d-print-template/. The display we used was the 2.9inch E-Ink Module 296x128/2.9inch e-Paper Module by Waveshare. Links to: Amazon, Waveshare Wiki. The required "drivers" are in epd2in9/.

Installation

This assumes that you have an API token obtained from RMV Open Data.

  1. Download and install Raspbian Lite. This was tested with version Buster, late 2019. Also configure it such that internet access is possible. See headless setup.

  2. (Optional.) Update the system initially and reboot.

sudo apt update
sudo apt full-upgrade
sudo reboot now
  1. (Optional.) Enable automatic updates.
# install:
sudo apt install unattended-upgrades -y
# configure:
sudo dpkg-reconfigure -plow unattended-upgrades
  1. Install some dependencies
sudo apt install git python3-pip python3-pil python3-spidev python3-rpi.gpio python3-dateutil fonts-lato -y
  1. Enable SPI.

  2. Adjust the timezone to (for example) Germany/Berlin. This can be done from within sudo raspi-config and checked with the date command. Restart after this just to be sure. ;)

  3. Clone the git repo onto the Pi. This assumes that the code was cloned into /home/pi, making the entry point sit at /home/pi/rmv-rpi-display/app.py.

git clone https://github.com/felixdivo/rmv-rpi-display.git
  1. Adjust API_TOKEN, ORIGIN_ID and DESTINATION_ID in rmv_api.py. The IDs are taken from the first row ("HAFAS_ID") of the official list of stations found on the RMV Open Data platform. Test execute it with:
cd the/directory/where/you/placed/it/
python3 app.py
  1. Make it start automatically. Add the following line on the line before the final exit 0 of /etc/rc.local (if you cloned it into /home/pi):
su pi -c "python3 /home/pi/rmv-rpi-display/app.py &"
  1. Pure happiness and never being late for the bus or tram.

Copyright

MIT License

Copyright (c) 2019 Felix Divo & Jonas Weidmann

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.