Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jeertmans/jinglebox
Automated Jingles for Sports Tournaments
https://github.com/jeertmans/jinglebox
automation python tournament-manager
Last synced: about 5 hours ago
JSON representation
Automated Jingles for Sports Tournaments
- Host: GitHub
- URL: https://github.com/jeertmans/jinglebox
- Owner: jeertmans
- License: mit
- Created: 2023-08-05T21:27:08.000Z (about 1 year ago)
- Default Branch: main
- Last Pushed: 2024-08-23T12:34:38.000Z (about 1 month ago)
- Last Synced: 2024-08-23T17:20:24.085Z (about 1 month ago)
- Topics: automation, python, tournament-manager
- Language: Python
- Homepage:
- Size: 149 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# JingleBox
A small program that automates playing jingles for sport tournaments.
![Graphical User Interface](https://github.com/jeertmans/jinglebox/assets/27275099/eaa0db1b-4963-419a-9363-b3ce0d687eeb)
## Use case
You are organizing a sport tournament, and games are played every X minutes?
JingleBox can play jingles for every game,
at very precise time moments.
If you are using another software for playing music during the whole event
(e.g., *Chrome*), then it will automatically reduce its volume when jingles
are played.All the parameters can be modified through the program, and changes will
occur in real time!## Usage
Depending on your profile, there are two ways to use this application
on your computer.The requirements are:
- a computer running Windows, Linux, or macOS;
- an application playing music in the background
(by default, it assumes that you use the *Chrome* web browser to play sound, e.g.,
on *Spotify* or *YouTube*, but you could use any other application,
such as the *Spotify* desktop application directly[^1]);
- a TOML config file describing **what jingles** should be played and **when**, see
[`jingles.example.toml`](./jingles.example.toml);
- and, of course, the soundfiles with the audio samples to play for each jingle.[^1]: It has been observed on Windows that controlling the sound level of
the *Spotify* desktop application does not work, while inside *Chrome* yes.> [!IMPORTANT]
>
> The filepaths (i.e., `file = ...`) to the sound files **must be relative**
> to the location of your configuration file. The easiest way to do so
> is to follow the same structure as this project:
> ```
> .
> ├── jingles.example.toml
> └── jingles
> ├── 1-next-in-one-minute.mp3
> ├── 2-time-is-running.mp3
> ├── 3-halftime.mp3
> ├── 4-one-minute-left.mp3
> └── 5-time-is-over.mp3
> ```### Download the latest executable
If you are a non-programmer, the easiest way to use this application is to download
a pre-built executable. The file is relatively large, but should run the app
without any extra installation from yourself!Click on the icon corresponding to your OS to download the latest version of JingleBox,
as well as example jingles:#### Linux / macOS
To execute the application, you may need to make the file *executable*,
this can either be done with a *right click* and a change in the file permissions,
or in the command line:```bash
chmod +x jinglebox
```#### Windows
On the first execution, Windows will warn you about this software being **untrusted**.
You can safely ignore the warning by clicking on "*More info*" and "*Run anyway*".### Install locally with Python
This projects requires `Python>=3.10`. After cloning the repository locally,
you can simply install the application with `pip install .`.Then, you can run the application with: `jinglebox`.
### How it works
The application works with two possible states:
1. *Music*: the music is played at its default level when no jingles are played;
2. *Jingle*: the music level is reduced, and a jingle is played **on top**,
and the music is put back to its previous level.Depending on the parameters chosen for the games, such as the duration, the
software will automatically switch between (1) and (2), until the last game is played.## Help
If you ever need help with this software, please reach me using the GitHub
issues, or via my email:
[[email protected]](mailto:[email protected]).