2024-09-23 21:59:07 +02:00
|
|
|
# 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.
|
|
|
|
|
2024-09-30 12:28:08 +02:00
|
|
|
![example image](media/example1.png)
|
2024-09-30 07:46:57 +02:00
|
|
|
|
2024-09-28 00:06:22 +02:00
|
|
|
## Disclaimer
|
|
|
|
|
|
|
|
**All** of the audio files played in lowfi are from [Lofi Girl's](https://lofigirl.com/) website,
|
|
|
|
under their [licensing guidelines](https://form.lofigirl.com/CommercialLicense).
|
|
|
|
|
|
|
|
If god forbid you're planning to use this in a commercial setting, please
|
|
|
|
follow their rules.
|
|
|
|
|
2024-09-23 21:59:07 +02:00
|
|
|
## Why?
|
|
|
|
|
|
|
|
I really hate modern music platforms, and I wanted a small, "suckless"
|
|
|
|
app that would literally just play lofi without video so I could use it
|
|
|
|
whenever.
|
2024-09-26 16:13:40 +02:00
|
|
|
|
|
|
|
I also wanted it to be fairly resiliant to inconsistent networks,
|
|
|
|
so it buffers 5 whole songs at a time instead of parts of the same song.
|
2024-09-28 00:06:22 +02:00
|
|
|
|
|
|
|
Although, lowfi is yet to be properly tested in difficult conditions,
|
|
|
|
so don't rely on it too much until I do that. See [Scraping](#scraping) if
|
|
|
|
you're interested in downloading the tracks. Beware, there's a lot of them.
|
|
|
|
|
2024-09-28 00:39:01 +02:00
|
|
|
## Installing
|
|
|
|
|
2024-10-01 19:36:35 +02:00
|
|
|
You'll need Rust 1.74.0+.
|
|
|
|
|
2024-10-04 11:38:12 +02:00
|
|
|
If you're on linux, you also need the OpenSSL & Alsa headers.
|
2024-10-04 11:37:52 +02:00
|
|
|
Alsa can be installed with `alsa-lib` on Arch or `libasound2-dev` on Ubuntu.
|
|
|
|
|
2024-09-28 00:39:01 +02:00
|
|
|
### Cargo
|
|
|
|
|
|
|
|
The recommended installation method is to use cargo:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
cargo install lowfi
|
|
|
|
```
|
|
|
|
|
2024-10-01 19:36:35 +02:00
|
|
|
and making sure `$HOME/.cargo/bin` is added to `$PATH`.
|
2024-09-28 00:39:01 +02:00
|
|
|
|
|
|
|
### AUR
|
|
|
|
|
|
|
|
If you're on Arch, you can also use the AUR:
|
|
|
|
|
|
|
|
```sh
|
|
|
|
yay -S lowfi
|
|
|
|
```
|
|
|
|
|
2024-10-05 13:34:54 +03:00
|
|
|
### Manual
|
|
|
|
|
|
|
|
```sh
|
|
|
|
git clone https://github.com/talwat/lowfi
|
|
|
|
cd lowfi
|
|
|
|
|
|
|
|
cargo build --release
|
|
|
|
./target/release/lowfi
|
|
|
|
```
|
|
|
|
|
2024-09-28 00:06:22 +02:00
|
|
|
## Usage
|
|
|
|
|
|
|
|
`lowfi`
|
|
|
|
|
|
|
|
Yeah, that's it. Controls are documented in the app.
|
|
|
|
|
2024-10-02 18:39:30 +02:00
|
|
|
### Extra Flags
|
|
|
|
|
2024-10-07 14:40:39 +02:00
|
|
|
If you have something you'd like to tweak about lowfi, you can run `lowfi help`
|
|
|
|
to view the available options.
|
2024-10-02 18:39:30 +02:00
|
|
|
|
2024-09-28 00:06:22 +02:00
|
|
|
### 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`.
|