Randomly change wallpaper for given monitor(s) in hyprpaper.
Project description
Pyprpaper
Pyprpaper is a hyprpaper client, its main
purpose is to change wallpapers randomly
(for given set of monitors) from a given
directory(ies).
Features
- Randomly change wallpapers for given monitors.
- Recursive image look-up in all directories.
- Timer to change wallpaper each n seconds.
- Support for none-hyprpaper/hyprland setup.
Installation
You can install pyprpaper using pip:
pip install pyprpaper
It is also available in the AUR (pyprpaper) for the arch linux btw users:
# With yay
yay -S pyprpaper
The PKGBUILD and .SRCINFO files are at
rofe33/pyprpaper-aur.
Usage
usage: pyprpaper [-h] [-v] -m monitor1 monitor2 [monitor1 monitor2 ...]
[-s SOCKET_PATH] [-k] [-K] [-r]
[-f [additional file types ...]] [-t TIMER]
path/to/directories [path/to/directories ...]
A simple wallpaper changer.
positional arguments:
path/to/directories Path to directories containing the images.
options:
-h, --help show this help message and exit
-v, --version show program's version number and exit
-m monitor1 monitor2 [monitor1 monitor2 ...], --monitors monitor1 monitor2 [monitor1 monitor2 ...]
Monitor(s) to change wallpapers on.
-s SOCKET_PATH, --socket-path SOCKET_PATH
Override socket path.
-k, --keep-wallpapers-loaded
Whether to keep wallpapers loaded in RAM or not.
-K, --keep-wallpapers-consistent
Whether to randomly set the same wallpaper for all the
monitors.
-r, --recursive Whether to recursive get the images from the
directories.
-f [additional file types ...], --additional-file-types [additional file types ...]
Additional image file types.
-t TIMER, --timer TIMER
Timer to change the wallpaper each n seconds
All The Glory To Jesus God...
Example
Change wallpaper for all monitors in hyprland/hyprpaper set-up:
pyprpaper -m $(hyprctl -j monitors | jq -r '.[].name' | tr '\n' ' ') -- /path/to/wallpaper/directories
My Hyprpaper/Pyprpaper setup
I am running hyprland/hyprpaper, if you are not
using hyprland things will defer depending on what
you are using. However pyprpaper will work on
any wayland compositor if you are using hyprpaper.
You can have an empty hyprpaper.conf setup
and just run pyprpaper in the exec-once in
hyprland.conf.
My current hyprpaper.conf config:
splash = off
and in hyprland.conf I have:
exec-once = pyprpaper -t 600 -m $(hyprctl -j monitors | jq -r '.[].name' | tr '\n' ' ') -- /path/to/directory(ies)
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file pyprpaper-0.3.2.tar.gz.
File metadata
- Download URL: pyprpaper-0.3.2.tar.gz
- Upload date:
- Size: 30.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
411b8a6b8b57f8b3140e503e4ca21b9e66a7aeaff487ffb410a9d117b5482cf1
|
|
| MD5 |
5d121892d2977f30bce3bf42897917b7
|
|
| BLAKE2b-256 |
53209db4355430b12b03e1d5d13a40c06ebcdc2a7b675538252f8a9fade9620b
|
File details
Details for the file pyprpaper-0.3.2-py3-none-any.whl.
File metadata
- Download URL: pyprpaper-0.3.2-py3-none-any.whl
- Upload date:
- Size: 29.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0370bc00bf77ae1327426b8e96fdc0db528afdce041c2f25c6a7474fff57b3f8
|
|
| MD5 |
4ec6396b8785e26ec30b3e511fec28f1
|
|
| BLAKE2b-256 |
69b34457ba71f16ceb12e1f70d1c821416baebd249cba458083845eb279b4818
|