lowfi
lowfi is a tiny rust app that serves a single purpose: play lofi. It'll do this as simply as it can: no albums, no ads, just lofi.
Disclaimer
As of the 1.7.0 version of lowfi, all of the audio files embedded by default are from chillhop.
Why?
I really hate modern music platforms, and I wanted a small, "suckless" app that would just play random lofi without video.
It was also designed to be fairly resilient to inconsistent networks, and as such it buffers 5 whole songs at a time instead of parts of the same song.
See Scraping if you're interested in downloading the tracks. Beware, there's a lot of them.
Installing
Note
If you're interested in maintaining a package for
lowfi
on package managers such as homebrew and the like, open an issue.
Dependencies
You'll need Rust 1.74.0+.
On MacOS & Windows, no extra dependencies are needed.
On Linux, you'll also need openssl & alsa, as well as their headers.
alsa-lib
on Arch,libasound2-dev
on Ubuntu.openssl
on Arch,libssl-dev
on Ubuntu.
Make sure to also install pulseaudio-alsa
if you're using PulseAudio.
Cargo
The recommended installation method is to use cargo:
cargo install lowfi
# If you want MPRIS support.
cargo install lowfi --features mpris
and making sure $HOME/.cargo/bin
is added to $PATH
.
Release Binaries
If you're struggling or unwilling to use cargo, you can just download precompiled binaries from the latest release.
AUR
yay -S lowfi
openSUSE
zypper install lowfi
Debian
Note
This uses an unofficial Debian repository maintained by Dario Griffo.
curl -sS https://debian.griffo.io/3B9335DF576D3D58059C6AA50B56A1A69762E9FF.asc | gpg --dearmor --yes -o /etc/apt/trusted.gpg.d/debian.griffo.io.gpg
echo "deb https://debian.griffo.io//apt $(lsb_release -sc 2>/dev/null) main" | sudo tee /etc/apt/sources.list.d/debian.griffo.io.list
sudo apt install -y lowfi
Fedora (COPR)
Note
This uses an unofficial COPR repository by FurqanHun.
sudo dnf copr enable furqanhun/lowfi
sudo dnf install lowfi
Manual
This is good for debugging, especially in issues.
git clone https://github.com/talwat/lowfi
cd lowfi
# If you want an actual binary
cargo build --release --all-features
./target/release/lowfi
# If you just want to test
cargo run --all-features
Usage
lowfi
Yeah, that's it.
Controls
Key | Function |
---|---|
s , n , l |
Skip Song |
p , Space |
Play/Pause |
+ , = , k , ↑ |
Volume Up 10% |
→ |
Volume Up 1% |
- , _ , j , ↓ |
Volume Down 10% |
← |
Volume Down 1% |
q , CTRL+C |
Quit |
Note
Besides its regular controls, lowfi offers compatibility with Media Keys and MPRIS (with tools like
playerctl
).MPRIS is currently optional feature in cargo (enabled with
--features mpris
) due to it being only for Linux, as well as the fact that the main point of lowfi is it's unique & minimal interface.
Extra Flags
If you have something you'd like to tweak about lowfi, you use additional flags which
slightly tweak the UI or behaviour of the menu. The flags can be viewed with lowfi help
.
Flag | Function |
---|---|
-a , --alternate |
Use an alternate terminal screen |
-m , --minimalist |
Hide the bottom control bar |
-b , --borderless |
Exclude borders in UI |
-p , --paused |
Start lowfi paused |
-d , --debug |
Include ALSA & other logs |
-w , --width <WIDTH> |
Width of the player, from 0 to 32 [default: 3] |
-t , --track-list <TRACK_LIST> |
Use a custom track list |
-s , --buffer-size <BUFFER_SIZE> |
Internal song buffer size [default: 5] |
Scraping
lowfi also has a scrape
command which is usually not relevant, but
if you're trying to download some files from Lofi Girls' website,
it can be useful.
An example of scrape is as follows,
lowfi scrape --extension zip --include-full
where more information can be found by running lowfi help scrape
.
Custom Track Lists
Note
Some nice users, especially danielwerg, have aleady made alternative track lists located in the data directory of this repo. You can use them with lowfi by using the
--tracks
flag.Feel free to contribute your own list with a PR.
lowfi also supports custom track lists, although the default one from Lofi Girl is embedded into the binary.
To use a custom list, use the --tracks
flag. This can either be a path to some file,
or it could also be the name of a file (without the .txt
extension) in the data
directory.
Note
Data directories:
- Linux -
~/.local/share/lowfi
- macOS -
~/Library/Application Support/lowfi
- Windows -
%appdata%\Roaming\lowfi
For example, lowfi --tracks minipop
would load ~/.local/share/lowfi/minipop.txt
.
Whereas if you did lowfi --tracks ~/Music/minipop.txt
it would load from that
specified directory.
All tracks must be in the MP3 format, unless lowfi has been compiled with the
extra-audio-formats
feature which includes support for some others.
The Format
In lists, the first line is what's known as the header, followed by the rest of the tracks. Each track will be first appended to the header, and then use that to download the track.
Note
lowfi will not put a
/
between the base & track for added flexibility, so for most cases you should have a trailing/
in your header.
The exception to this is if the track name begins with a protocol like https://
,
in which case the base will not be prepended to it. If all of your tracks are like this,
then you can put noheader
as the first line and not have a header at all.
For example, in this list:
https://lofigirl.com/wp-content/uploads/
2023/06/Foudroie-Finding-The-Edge-V2.mp3
2023/04/2-In-Front-Of-Me.mp3
https://file-examples.com/storage/fe85f7a43b689349d9c8f18/2017/11/file_example_MP3_1MG.mp3
lowfi would download these three URLs:
https://lofigirl.com/wp-content/uploads/2023/06/Foudroie-Finding-The-Edge-V2.mp3
https://file-examples.com/storage/fe85f7a43b689349d9c8f18/2017/11/file_example_MP3_1MG.mp3
https://lofigirl.com/wp-content/uploads/2023/04/2-In-Front-Of-Me.mp3
Additionally, you may also specify a custom display name for the track which is indicated by a !
.
For example, if you had an entry like this:
2023/04/2-In-Front-Of-Me.mp3!custom name
Then lowfi would download from the first section, and display the second as the track name.
You can also prepend file://
to the header track name, which will make lowfi treat it as a local file.
This is useful if you want to use a local file as the base URL, such as:
file:///home/user/Music/
file.mp3
file:///home/user/Other Music/second-file.mp3
Further examples can be found in the data folder.