dublinbus-display
Go to file
Nahuel Lofeudo 8bf7503a39 Do not initialize Pygame modules that we don't use (avoid sound underruns) 2023-07-09 22:01:49 +01:00
Enclosure Update enclosure model. Ignore exported STLs 2023-06-24 05:22:51 +01:00
systemd Added service file. Improvements to the readme. 2022-12-18 18:53:22 +00:00
.gitignore Update gitignore 2023-06-24 22:45:30 +01:00
LICENSE Initial commit 2022-09-11 02:59:00 -07:00
README.md Add yaml to the list of dependencies 2023-05-06 10:30:49 +01:00
arrival_times.py Add support for GTFS-R added routes 2023-05-06 18:48:40 +01:00
config.py Fix lookup of walk time to the stop 2023-06-24 22:44:03 +01:00
config.yaml Update GTFS-R URL for nationaltransport.ie 2023-06-20 06:26:29 +01:00
gtfs_client.py Fix lookup of walk time to the stop 2023-06-24 22:44:03 +01:00
main.py Do not initialize Pygame modules that we don't use (avoid sound underruns) 2023-07-09 22:01:49 +01:00
refresh_feed.py Move the feed .zip file to /tmp. Add debug info on refresh. 2023-06-24 05:55:23 +01:00
requirements.txt First version 2022-09-11 11:12:51 +01:00

README.md

dublinbus-display

Emulates a Dublin Bus electronic sign, showing ETAs for different bus lines

How to use it

  1. Clone the repository into your /home/pi directory.
  2. (optional) Configure the Raspberry Pi to use the non-standard display.
  3. Install all dependencies.
  4. Download the TTF font into the program's directory.
  5. Change main.py, updating STOPS to reflect the stop(s) you want to watch.
  6. Run main.py

1. Configure the Raspberry Pi (pi-specific)

1.1 - Disable boot messages

Open /boot/cmdline.txt and add the parameter quiet at the end of the line.

1.2 - Configure the display aspect ratio (only for ultrawide monitors)

If you plan on using an ultrawide monitor with a similar aspect ratio as the actual Dublin Bus displays (e.g. HSD123KPW2-D10), add the following lines to your /boot/config.txt:

framebuffer_width=1920
framebuffer_height=720

hdmi_ignore_edid=0xa5000080
hdmi_group=2
hdmi_mode=87
disable_overscan=1
hdmi_timings=1920 0 88 44 148 720 0 4 5 36 0 0 0 60 0 100980000 1

If your display's resolution is not 1920x720, you will also need to change the code to adapt to your specific size.

2. Install all dependencies

  • iso8601
  • zeep
  • libSDL2_ttf-2.0.so.0
  • python3-numpy
  • python3-pandas
  • python3-fiona
  • python3-pyproj (to build gtfs_kit2)
  • libspatialindex-c6
  • yaml
$ sudo apt install python3-iso8601 python3-zeep libsdl2-ttf-2.0-0 python3-numpy python3-pandas python3-fiona python3-pyproj libspatialindex-c6 python3-yaml
  • pygame 2
  • GTFS-Kit
$ sudo pip3 install pygame gtfs_kit

3. Set up the services

3.1 - Disable login on tty1:

$ sudo systemctl disable getty@tty1
$ sudo systemctl stop getty@tty1

3.2 - Create a service file to auto-start the display program

First, create a link from the provided systemd service into the systemd directory

$ sudo ln -s /home/pi/dublinbus-display/systemd/dublinbus-display.service /etc/systemd/system/

Enable and start the service

$ sudo systemctl daemon-reload
$ sudo systemctl enable dublinbus-display
$ sudo systemctl start dublinbus-display

Restart the system

$ sudo reboot