dublinbus-display
Go to file
Nahuel Lofeudo b5d9fa1dd8 Add timeouts to the calls to the GTFS-R API 2023-11-11 15:46:51 +00: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 Replace ad-hoc scheduler with package schedule 2023-09-17 17:47:08 +01:00
arrival_times.py Add support for GTFS-R added routes 2023-05-06 18:48:40 +01:00
config.py Make the font file configurable. 2023-08-27 16:46:16 +01:00
config.yaml Make the font file configurable. 2023-08-27 16:46:16 +01:00
gtfs_client.py Add timeouts to the calls to the GTFS-R API 2023-11-11 15:46:51 +00:00
main.py Add some last-resort exception handling 2023-10-08 15:27:35 +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 apt install python3-pip
$ sudo pip3 install pygame gtfs_kit schedule --break-system-packages

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