- Published on
Blitz Gym - Automated HIIT Classes
- Authors
Blitz was designed as new style of semi-automated gym, focusing on circuits and HIIT. The gym space was organised into twelve stations with a screen above each that run 24/7.
On each screen would be a video of the exercise to perform, a timer, and a countdown to the next station. The idea was to have a digital-first gym where the screens would guide the user through the workout.
Requirements
- The system needed to be configurable by gym employees, so they could change the workout plan, the exercises, the timings, and the order of the stations.
- Exercise videos can be uploaded by Gym employees and associated with the correct exercise.
- Gym screens should be able to connect to the system and display the workout for each station.
- Timers on each screen should be closely synchronised.
- The system should be able to handle multiple gyms, each with their own workout plan.
Constraints
- Gym internet connection quality is inconsistent, so the system should be continue to work offline.
- Gym screens are cheap and have limited processing power, so the system should be lightweight.
- TV O/S has been recommended as Android, but this may change in the future.
- Hosting costs should be kept to a minimum.
- Maintenance should be simple and not require a dedicated IT team.
Design
Components
- Android App: This is the app that runs on the gym screens. It connects to the Azure SignalR service to receive updates on the workout plan and timings.
- Built using Flutter
- Runs on Android TV
- Web App: This is the app that allows employees to manage content and start/stop programmes. This is deployed to Azure Static Web Apps.
- Built using Next-JS
- Hosted on Azure Static Web Apps
- API: An API layer for the web app to upload videos and manage workouts. This API must also trigger the gym screens to update and start/stop.
- Built and hosted using Azure Functions
- Uses SignalR to trigger gym screens
- Database: This is used to store the workout plans and exercise videos. It is accessed by the web app and API.
- Built using Azure Cosmos DB
- Video Storage: This is used to store the exercise videos. It is accessed by the Web app for preview and Android App to display content in the gym.
- Implemented with Azure Blob Storage
Final Product
The final product was a success. The gym screens were able to connect to the system and display the workout plan. The timers were synchronised across all screens. Gym employees were able to upload new exercise videos and change the workout plan.
Problems Encountered
- Video downloads - The Flutter app had issues streaming videos from Azure Blob Storage. This was resolved by implementing a cache within the Flutter app.
- Timers stopping when the internet connection was lost - This was resolved by designating one screen as the master screen. If the master screen lost connection, another screen would take over as master. The master screen would then broadcast the workout plan and timings to the other screens using UDP broadcast.
- Video sizes - videos taken by employees were large, so videos had to be compressed and re-encoded before being uploaded to Azure Blob Storage. This was done using FFmpeg in a Web Worker within the Next-JS app.