2021-12-16 20:49:41 +01:00
# Music player demo
## Overview
2022-03-21 18:25:51 +08:00
The music player demo shows what kind of modern, smartphone-like user interfaces can be created on LVGL. It works the best with display with 480x272 or 272x480 resolution.
2021-12-16 20:49:41 +01:00
2022-07-06 03:06:31 -04:00
![Music player demo with LVGL embedded GUI library ](screenshot1.gif )
2021-12-16 20:49:41 +01:00
## Run the demo
2022-01-20 18:52:52 +00:00
- In `lv_conf.h` or equivalent places set `LV_USE_DEMO_MUSIC 1`
2021-12-16 20:49:41 +01:00
- With `LV_DEMO_MUSIC_AUTO_PLAY` enabled a ~60 sec demo will be played.
- After `lv_init()` and initializing the drivers call `lv_demo_music()`
## How the spectrum animation works
- `assets/spectrum.py` creates an array of spectrum values from a music. 4 band are created with 33 samples/sec: bass, bass-mid, mid, mid-treble.
2023-08-14 22:49:30 +08:00
- The spectrum meter UI does the following:
2021-12-16 20:49:41 +01:00
- Zoom the album cover proportionality to the current bass value
2022-03-21 18:25:51 +08:00
- Display the 4 bands on the left side of a circle by default at 0°, 45°, 90°, 135°
2021-12-16 20:49:41 +01:00
- Add extra bars next to the "main bars" with a cosine shape. Add more bars for the lower bands.
2022-01-17 14:10:23 +01:00
- If there is a large enough bass, add a random offset to the position of the bars. E.g. start from 63° instead of 0°. (bars greater than 180° start again from 0°)
- If there is no bass, add 1 to the offset of the bars (it creates a "walking" effect)
2021-12-16 20:49:41 +01:00
- Mirror the bars to the right side of the circle
## Using spectrum.py
- install `librosa` with `pip3 install librosa`
2024-06-28 03:09:23 -04:00
- run `python spectrum.py my_file.mp3`
2021-12-16 20:49:41 +01:00
- see the result in `spectrum.h`