This repository contains the code we originally developed to assist with Firefighter competitions.
- Measure split time and total time for each team
- On each checkpoint, also measure pressure, water flow, and engine RPMs
- Display results on the screen
- Store data into CSV file for later analysis
This tool was originally written for the Raspberry Pi. If you install the latest Raspberry Pi OS with GUI and all the Python libraries specified in the requirements.txt file, you should have no issues running it. All sensors and triggers for this application should be connected to the Raspberry Pi GPIO bus. For the exact pinout, see the script source code.
- Gpiozero - creates an abstraction layer over Raspberry Pi's GPIO. Working with the GPIO bus is then easier.
- Pillow - displays images in the GUI
- Adafruit libraries - used for communication with sensors
- Tcl/Tk - GUI library
- Some other dependencies. For a complete list, see the requirements.txt file
- First, install and configure the Gpiozero library, as instructed here
- Then, download this repository, e.g., into the
Documents
folder
[pi@raspberry Documents]$ git clone https://github.com/JSC-electronics/firefighter-stopwatch.git
Cloning into 'firefighter-stopwatch'...
remote: Enumerating objects: 167, done.
remote: Counting objects: 100% (167/167), done.
remote: Compressing objects: 100% (67/67), done.
remote: Total 167 (delta 94), reused 167 (delta 94), pack-reused 0
Receiving objects: 100% (167/167), 62.68 KiB | 197.00 KiB/s, done.
Resolving deltas: 100% (94/94), done.
[pi@raspberry Documents]$
- Create Python virtual environment:
[pi@raspberry firefighter-stopwatch (develop)]$ python3 -m venv venv
created virtual environment CPython3.8.6.final.0-64 in 191ms
creator CPython3Posix(dest=/home/vzahradnik/Documents/firefighter-stopwatch/venv, clear=False, global=False)
seeder FromAppData(download=False, pip=bundle, setuptools=bundle, wheel=bundle, via=copy, app_data_dir=/home/vzahradnik/.local/share/virtualenv)
added seed packages: pip==20.1.1, setuptools==50.2.0, wheel==0.35.1
activators BashActivator,CShellActivator,FishActivator,PowerShellActivator,PythonActivator,XonshActivator
- Load the environment and install required libraries
source venv/bin/activate
python -m pip install -r requirements.txt
- Install Tcl/Tk GUI library using
apt-get
. Python provides only bindings to control the library, but it must be installed system-wide - Finally, you can run the script
python stopwatch.py
One of the reasons we used the Gpiozero library was that it supports a remote GPIO
. If you have a Raspberry Pi, you can hook up all sensors into the RPi, set up a GPIO server, and then connect to the RPi from your PC. The code will work as if it was run on the Raspberry Pi. Please follow this guide to make it work.
- The Adafruit libraries, which are used to read water pressure, don't support running on a PC. Therefore, our script disables pressure measurement. Other features should work fine.
- This script was also modified to be run without any additional config. However, in this case, there's nothing much to do. All the functionality requires GPIO access. Without GPIO, you can at least see the GUI.
We know this application was developed for very specific usage. However, it still demonstrates how to build a decent GUI, work with GPIO bus, evaluate data in a background thread, etc.
stopwatch.py
- main script fileconfig.json
- contains configuration variables. If the script doesn't find the config, it still contains reasonable defaultsgfx/
- graphical assets used in the GUIl10n
- app translations
Our script uses relative paths, so if you keep the folder structure, everything should work OK.
Originally, our GUI was in the Czech language. To make it easier for you, we implemented translations using GNU gettext. Now you should see the GUI in English while we also maintain Czech and Slovak translations.
Copyright (c) 2019-2020 JSC electronics. All rights reserved.
Licensed under the Apache-2.0 license.