This project provides a free Raspbian based Raspberry Pi image with NHL LED Scoreboard pre-installed. This is built with the Hasicorp packer with the packer-builder-arm plugin (https://github.com/mkaczanowski/packer-builder-arm) in a docker image extended with ansible. Ansible is used to do the provisioning of the image. For more information, see the BUILD documentation.
- Works on all Raspberry Pi models
- Built on Raspbian Lite (no desktop). As of March 2024, current image build runs on latest RaspiOS Bookworm lite.
- Simple WiFi Setup (Ethernet setup not tested and should only be done by advanced users) using the comitup utility.
This image also provides a command called sb-tools
which helps you with various tools to run and configure the scoreboard in a text/terminal based GUI. There are also a set of command line aliases that provide similar functionaity without a GUI. See Command Line Utilities for a list.
Everything python related is now installed in a virtual environment that is located in the /home/pi/nhl-led-scoreboard/venv directory. The bashrc script contains code that will auto activate the venv and deactivate upson entering and leaving the /home/pi/nhl-led-scoreboard directory. The purpose behind this is to keep the OS install as clean as possible and the Python 3.11 in Bookworm will not let you install over system installed packages. In order to run the code from the command line using sudo, the python command must
now reference the virtual environment installation and not the globally installed one. Everything is handled with the image but if you are asked to run the code via command line for troubleshooting issues, see below.
Here's a comparison of how to run the scoreboard (assuming you are in the nhl-led-scoreboard directory)
Previous way with everything globally install as root user
sudo python3 ./src/main.py [command line options]
Now with the venv
sudo /home/pi/nhlsb-venv/bin/python3 ./src/main.py [command line options]
Also, when you change to the nhl-led-scoreboard directory, your virtual environment will automatically be activate (and deactivated when you leave it). You can tell your virtual environment is active by your shell prompt. This is what it looks like under raspiOS Bullseye.
(nhlsb-venv)pi@scoreboard: ~/nhl-led-scoreboard (master)$
The front part of your prompt shows the name of the virtual environment. The part after the nhl-led-scoreboard shows the git branch.
Downloading the NHL LED Scoreboard Raspberry Pi Image is completely free (no sign up required).
If you'd like to support me:
The easiest way to flash the NHL LED Scoreboard Raspberry Pi Image to your SD card is to use Etcher. If you decide to use the official Raspberry Pi IMager, make sure you DO NOT apply any customizations to the OS when it gets transferred to the SD card. If you do, your SD card will not work as intended for this project (if at all).
- Download and install the latest version of Etcher.
- Open Etcher and select the
rpios-scoreboard-v0.0.0.xz
file you have downloaded. There is no need to extract the.xz
file first. - Choose the drive your SD card has been inserted into.
- Click Flash.
Now that you have flashed your SD card, you can insert it into your Raspberry Pi. Your Raspberry Pi will expand the size of your SD card to utilize it fully. This can take some time depending on the size and health of your card. Once the Raspberry Pi has expanded the filesystem, it will launch a Captive Portal that you can log into to set your WiFi. On an iPhone, this should open safari automatically. On Android 10 and 11, it shows up as manage your router in the WiFi details in the settings. Android now will open captive portal webpage automatically as well. If you don't see it, use the manage router in WiFi details.
Default Hostname | scoreboard.local |
Default SSH Username | pi |
Default SSH Password | scoreboard |
Hot Spot Wifi SSID | scoreboard-#### |
####
will be set to the a random set of 4 digits.
Follow these steps to connect your device to WiFi:
- Power on your device without an Ethernet cable attached.
- Wait 1-2 minutes (if first boot, the SD card will need to be expanded so this may take longer)
- Use your mobile phone to scan for new WiFi networks
- Connect to the hotspot named scoreboard-#### where
####
is the a random set of 4 digits. There is no wifi password required. - Wait a few moments until the captive portal opens, this portal will allow you to connect the Raspberry Pi to your local WiFi network. If the captive portal does not open, connect to your raspberry pi at
http://10.41.0.1
If you enter your WiFi credentials incorrectly the NHL Led Scoreboard hotspot will reappear allowing you to try again.
After you set your WiFi connection, the raspberry pi will reboot and connect to your router. To find your raspberry pi, the following can be attempted:
- Login to your router and find the "connected devices" or "dhcp clients" page to find the IP address that was assigned to the Raspberry Pi.
- Download the Fing app for iOS or Android to scan your network to find the IP address of your Raspberry Pi.
- Try to
ping scoreboard.local
. The ping will show the IP address of your pi.
See the wiki How to Find IP Address
SSH is enabled by default. The default username is pi
with password scoreboard
.
See the wiki Connect with SSH for more information and links.
You will need to SSH to your Raspberry Pi to finalize some settings for getting the NHL LED Scoreboard to work. On first login, you will be prompted to select a single team (to create a basic config.json), the size of your board and if you have the antiflicker mod for the adafruit boards, then it will run a test script that will display the latest version of the NHL LED Scoreboard software. If that passes, you will be asked to enable the supervisor and then the raspberry pi will reboot.
On reboot, if everything is working you will see a splash screen, then a loading image and the NHL LED Scoreboard will run wth the basic config.json created on the first initial log in. If you want to change the config.json, either edit the file by hand or use the /home/pi/nhl-led-scoreboard/nhl_setup tool.
The official NHL LED Scoreboard Discord server where users can discuss NHL LED Scoreboard and ask for help.
This table contains important information about the command line tools you can use.
General Tools | Command |
---|---|
Help Command | sb-help |
Manage NHL LED Scoreboard | sb-tools |
system info Command | sb-sysinfo |
Reset Wifi to Hot Spot | sb-resetwifi |
Troubleshooting Tools | Command |
---|---|
View Live Logs Command | sb-livelog |
View output, last 50kb | sb-stdout |
View errors, last 50kb | sb-stderr |
Collect files for github issue | sb-issue |
Update Tools | Command |
---|---|
Check for Update | sb-updatecheck |
Show changelog for latest version | sb-changelog |
Upgrade to latest version | sb-upgrade |
Supervisor/Process Tools | Command |
---|---|
Status Command | sb-status |
Restart Command | sb-restart |
Stop Command | sb-stop |
Start Command | sb-start |
This raspberry pi image is built on top of the latest Raspberry Pi OS lite Bullseye (May 3, 2023 release). Bookworm supported will be coming in the future.
Added to this version is the following:
- Auto set timezone based on geolocation of your IP address. Initial time zone is America/Toronto because we all know that's the center of the universe.
- There is a login banner that shows various system info for your raspberry pi (including timezone). It can manually be run by using the
sb-sysinfo
- /var/log, swap and /home/pi are all set to exist in zram. /var/log and /homepi will get written back to the SD card on boot or under a filesystem sync. Settings for the sizes are in /etc/ztab
- The size for zram of the /home/pi directory is currently set to 350M compressed. There is room for another repository to be installed if you wish. If you don't want the /home/pi to be run from zram, then edit the /etc/ztab as root user and comment out the line with /home/pi.
- raspi-config is still available with all options as a normal raspberry pi. So if your time zone is not set correctly or you don't like your hostname, you can still use raspi-config for changes
- Locale is set to en_US.UTF_8 which is needed for the weather icons to work correctly.