add switching random wallpaper every 60 seconds and base for matugen

This commit is contained in:
Sem
2026-03-29 22:36:31 +02:00
parent 53bdb29c8c
commit 06477003e0
4 changed files with 88 additions and 32 deletions

View File

@@ -41,12 +41,10 @@ $programs = rofi -show drun
# exec-once = nm-applet & # exec-once = nm-applet &
# exec-once = waybar & hyprpaper & firefox # exec-once = waybar & hyprpaper & firefox
# authentication exec-once = /usr/lib/hyprpolkitagent/hyprpolkitagent # authentication
exec-once = /usr/lib/hyprpolkitagent/hyprpolkitagent exec-once = /usr/bin/qs & # quickshell
# quickshell # exec-once = hyprpaper # wallpaper
exec-once = /usr/bin/qs & exec-once = awww-daemon # wallpaper
# wallpaper
exec-once = hyprpaper
############################# #############################
### ENVIRONMENT VARIABLES ### ### ENVIRONMENT VARIABLES ###
############################# #############################

View File

@@ -11,7 +11,7 @@ fallback_color = "#ffbf9b"
# Which color to choose if multiple good colors were found from an image. # Which color to choose if multiple good colors were found from an image.
# choices: [darkness, lightness, saturation, less-saturation, value, closest-to-fallback] # choices: [darkness, lightness, saturation, less-saturation, value, closest-to-fallback]
# The cli flag will override this if used. # The cli flag will override this if used.
prefer = "closest-to-fallback" prefer = "value"
# Enables caching which will cache the colorscheme, custom colors, etc. into a cache folder located in # Enables caching which will cache the colorscheme, custom colors, etc. into a cache folder located in
# Windows: C:\Users\user\AppData\Roaming\InioX\matugen\cache\images\<file> # Windows: C:\Users\user\AppData\Roaming\InioX\matugen\cache\images\<file>
@@ -34,7 +34,7 @@ block_postfix = "*>"
# Imports json files just like `--import-json` does. # Imports json files just like `--import-json` does.
# Relative paths will be resolved from the path `config.toml` is in. # Relative paths will be resolved from the path `config.toml` is in.
import_json_files = ["./custom3.json"] # import_json_files = ["./custom3.json"]
# Defaults to the contrast from CLI if unspecified. # Defaults to the contrast from CLI if unspecified.
# Value from -1 to 1. # Value from -1 to 1.
@@ -54,6 +54,13 @@ command = "swww img --transition-type center {{ image }}"
# For example, killing the wallpaper daemon. Usage is like a normal hook. # For example, killing the wallpaper daemon. Usage is like a normal hook.
# pre_hook = "" # pre_hook = ""
# If you don't want to use the other colors that are automatically generated (on_color, on_color_container) you can just import a custom json with the colors instead.
# For an example of importing json see: https://iniox.github.io/#matugen/usage/importing-json
[config.custom_colors]
red = "#ff0000"
blue = "#0000ff"
green = "#00ff00"
[templates.includeme] [templates.includeme]
input_path = "./include.txt" input_path = "./include.txt"
# The output path is optional if you just want to import the template anyways. # The output path is optional if you just want to import the template anyways.
@@ -115,10 +122,3 @@ expr_postfix = "}}"
# https://m3.material.io/styles/color/advanced/adjust-existing-colors#1cc12e43-237b-45b9-8fe0-9a3549c1f61e # https://m3.material.io/styles/color/advanced/adjust-existing-colors#1cc12e43-237b-45b9-8fe0-9a3549c1f61e
# If you want to use the original color without any harmonization, add `_source` after the name like: `{{ color_source }}` # If you want to use the original color without any harmonization, add `_source` after the name like: `{{ color_source }}`
# Example: To use the original red color you would use `{{ red_source }}` instead of `{{ red }}` # Example: To use the original red color you would use `{{ red_source }}` instead of `{{ red }}`
# If you don't want to use the other colors that are automatically generated (on_color, on_color_container) you can just import a custom json with the colors instead.
# For an example of importing json see: https://iniox.github.io/#matugen/usage/importing-json
[config.custom_colors]
red = "#ff0000"
blue = "#0000ff"
green = "#00ff00"

View File

@@ -0,0 +1,57 @@
import Quickshell
import Quickshell.Io
import QtQuick
Item {
id: wallpaperHolder
// Store all wallpapers
property var wallpapers: []
property string wallpaperDir: Qt.resolvedUrl("file:///home/sem/Pictures/wallpapers")
// process to run the command to change the wallpaper
Process {
id: wallpaperProcess
}
// Load wallpaper list once at startup
Process {
id: loadWallpapers
command: ["bash", "-c", "find ~/Pictures/wallpapers -type f"]
stdout: StdioCollector {
onStreamFinished: {
console.log("wallpapers loaded!");
wallpaperHolder.wallpapers = this.text.trim().split("\n");
wallpaperHolder.setRandomWallpaper();
}
}
}
function setRandomWallpaper() {
if (wallpapers.length === 0) {
console.log("No wallpapers found");
return;
}
var index = Math.floor(Math.random() * wallpapers.length);
var path = wallpapers[index];
console.log("wallpaper set to " + path);
wallpaperProcess.command = ["awww", "img", path, "--transition-type", "grow", "--transition-fps", "60", "--transition-duration", "0.6"];
wallpaperProcess.running = true;
}
Timer {
interval: 60000
running: true
repeat: true
onTriggered: wallpaperHolder.setRandomWallpaper()
}
Component.onCompleted: {
loadWallpapers.running = true; // start loading wallpapers
}
}

View File

@@ -5,6 +5,8 @@ import Quickshell.Io
import QtQuick import QtQuick
import QtQuick.Layouts import QtQuick.Layouts
import "."
// qmllint disable uncreatable-type // qmllint disable uncreatable-type
PanelWindow { PanelWindow {
id: root id: root
@@ -18,6 +20,8 @@ PanelWindow {
property var lastCpuIdle: 0 property var lastCpuIdle: 0
property var lastCpuTotal: 0 property var lastCpuTotal: 0
RandomWallpaper {}
Process { Process {
id: cpuProc id: cpuProc
// get cpu usage, first line of /proc/stat // get cpu usage, first line of /proc/stat
@@ -25,7 +29,6 @@ PanelWindow {
stdout: StdioCollector { stdout: StdioCollector {
onStreamFinished: { onStreamFinished: {
var line = this.text.split(/\r?\n/)[1].split(" "); var line = this.text.split(/\r?\n/)[1].split(" ");
console.log("the line is " + line);
var user = parseInt(line[1]); var user = parseInt(line[1]);
var nice = parseInt(line[2]); var nice = parseInt(line[2]);
@@ -45,8 +48,6 @@ PanelWindow {
root.cpuUsage = Math.round(100 * (1 - diffIdle / diffTotal)); root.cpuUsage = Math.round(100 * (1 - diffIdle / diffTotal));
} }
console.log("diffTotal is " + diffTotal);
root.lastCpuIdle = idleAll; root.lastCpuIdle = idleAll;
root.lastCpuTotal = total; root.lastCpuTotal = total;
} }